栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

操作'='的排序规则(utf8_unicode_ci,IMPLICIT)和(utf8_general_ci,IMPLICIT)的非法混合

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

操作'='的排序规则(utf8_unicode_ci,IMPLICIT)和(utf8_general_ci,IMPLICIT)的非法混合

存储过程参数的默认排序规则为

utf8_general_ci
并且您不能混合排序规则,因此有四个选项:

选项1 :添加

COLLATE
到您的输入变量中:

SET @rUsername = ‘aname’ COLLATE utf8_unipre_ci; -- COLLATE addedCALL updateProductUsers(@rUsername, @rProductID, @rPerm);

选项2

COLLATE
WHERe
条款中添加:

CREATE PROCEDURE updateProductUsers(    IN rUsername VARCHAr(24),    IN rProductID INT UNSIGNED,    IN rPerm VARCHAr(16))BEGIN    UPDATE productUsers        INNER JOIN users        ON productUsers.userID = users.userID        SET productUsers.permission = rPerm        WHERe users.username = rUsername COLLATE utf8_unipre_ci -- COLLATE added        AND productUsers.productID = rProductID;END

选项3 :将其添加到

IN
参数定义中:

CREATE PROCEDURE updateProductUsers(    IN rUsername VARCHAr(24) COLLATE utf8_unipre_ci, -- COLLATE added    IN rProductID INT UNSIGNED,    IN rPerm VARCHAr(16))BEGIN    UPDATE productUsers        INNER JOIN users        ON productUsers.userID = users.userID        SET productUsers.permission = rPerm        WHERe users.username = rUsername        AND productUsers.productID = rProductID;END

选项4 :更改字段本身:

ALTER TABLE users CHARACTER SET utf8 COLLATE utf8_general_ci;

除非您需要按Unipre顺序对数据进行排序,否则我建议您更改所有表以使用

utf8_general_ci
排序规则,因为它不需要更改代码,并且会稍微加快排序速度。

更新 :utf8mb4 /
utf8mb4_unipre_ci现在是首选的字符集/排序规则方法。建议不要使用utf8_general_ci,因为性能提升可忽略不计。参见https://stackoverflow.com/a/766996/1432614



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/421048.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号