位置: 编程技术 - 正文

mysql的校对规则引起的问题分析(mysql_real_query)

编辑:rootadmin
问题是这样的: 一张test的表,字符集采用的latin1。 select to_id from test where to_id='cn象_王'; +---------------+ | to_id | +---------------+ | cn陶_陶 | | cn象_王 | +---------------+ 2 rows in set (0. sec) 取cn象_王的数据,居然把cn陶_陶的数据也取回来了。 这显然是不允许的。 查看它们的编码: (root@im_offlog1a:)[test]> select hex('cn陶_陶'); +----------------+ | hex('cn陶_陶') | +----------------+ | ECCDFCCD5 | +----------------+ 1 row in set (0. sec) (root@im_offlog1a:)[test]> select hex('cn象_王'); +----------------+ | hex('cn象_王') | +----------------+ | ECFFFCDF5 | +----------------+ 1 row in set (0. sec) 编码的确是不一样的,但是为什么mysql会认为这两条记录是一样的呢? 一开始我们就把问题定位于collation引起的问题。 show variables查看 | collation_connection | latin1_swedish_ci | collation_database | latin1_swedish_ci | collation_server | latin1_swedish_ci 手工把这些参数修改为latin1_bin,结果居然一样。这下感觉真是奇怪了。 这里先解释一下mysql collation的命名规则: 它们以其相关的字符集名开始,通常包括一个语言名,并且以_ci(大小写不敏感)、_cs(大小写敏感)或_bin(二元)结束 比如latin1字符集有以下几种校正规则: 校对规则 含义 latin1_german1_ci 德国DIN-1 latin1_swedish_ci 瑞典/芬兰 latin1_danish_ci 丹麦/挪威 latin1_german2_ci 德国 DIN-2 latin1_bin 符合latin1编码的二进制 latin1_general_ci 多种语言(西欧) latin1_general_cs 多种语言(西欧ISO),大小写敏感 latin1_spanish_ci 现代西班牙 最后我们将表格重建,手工指定表格级别的collation为latin1_bin。 这个问题就得到了解决。 那么问题又来了,为什么我前面手工测试latin1_bin时不生效呢? 原来MySQL按照下面的方式选择表字符集和 校对规则: 如果指定了CHARACTER SET X和COLLATE Y,那么采用CHARACTER SET X和COLLATE Y。 如果指定了CHARACTER SET X而没有指定COLLATE Y,那么采用CHARACTER SET X和CHARACTER SET X的默认校对规则。 否则,采用服务器字符集和服务器校对规则。 而我们在建表的时候指定了character set,所以它永远是采用对应的默认的校对规则。 当然我们其实也没必要重建表格,只需要alter table db_allot CONVERT TO CHARACTER SET latin1 COLLATE latin1_bin这样转换即可。 另外建议collation都尽量采用字符集相应的bin类型的校对规则,这样不容易出错

推荐整理分享mysql的校对规则引起的问题分析(mysql_real_query),希望有所帮助,仅作参考,欢迎阅读内容。

mysql的校对规则引起的问题分析(mysql_real_query)

文章相关热门搜索词:mysql对齐,mysql字符集校对规则,mysql对齐,mysql对齐,mysql数据库时间校准,mysql怎么调试,mysql字符集校对规则,mysql设置校对规则,内容如对您有帮助,希望把文章链接给更多的朋友!

MySQL collation方法 问题是这样的:一张test的表,字符集采用的latin1。selectto_idfromtestwhereto_id='cn象_王';+---------------+|to_id|+---------------+|cn陶_陶||cn象_王|+---------------+2rowsinset(

mysql Myisamchk小工具使用手册第1/2页 1.myisamchk的调用方法myisamchk[options]tbl_name...其中options指定你想让myisamchk干什么。它允许你通过使用模式*.MYI指定在一个目录所有的表。shellmyisamchk*.MYI推荐

MySQL server has gone away错误提示解决方法 大概浏览了一下,主要可能是因为以下几种原因:一种可能是发送的SQL语句太长,以致超过了max_allowed_packet的大小,如果是这种原因,你只要修改my.cnf

标签: mysql_real_query

本文链接地址:https://www.jiuchutong.com/biancheng/319931.html 转载请保留说明!

上一篇:Mysql如何避免全表扫描的方法(mysql怎么防止sql注入)

下一篇:mysql Myisamchk小工具使用手册第1/2页(mysql使用工具)

  • 公司全额承担个税怎么申报
  • 向境外企业支付利息代扣代缴
  • 发票名称开错了但是税号没错怎么办
  • 土地使用税的纳税义务人
  • 捐赠资产管理办法
  • 报税期能不能开发票
  • 机械租赁小规模企业所得税
  • 创立一个公司,公司的运营理念
  • 税务登记法人变更后多久生效
  • 商业用房怎么缴税
  • 差旅费报销怎么做账
  • 提前预支费用怎么写
  • 汽车公司场地租金怎么算
  • 跨地区预缴税款需缴纳哪些
  • 免抵调增值税是否缴纳附加税
  • 现房销售需要哪些手续
  • 内账价税分离余额怎么处理
  • 待处理财产损益的二级科目
  • 企业收到进项发票
  • 事业单位去年的岗位今年还会招吗
  • 包装物怎么入账
  • 资源税进什么科目
  • 可供出售金融资产是指什么
  • 研发费用加计扣除最新政策2023
  • 工商年报需要什么数据
  • 即征即退的增值税计入其他收益吗
  • 顶账物品都有哪些
  • 往来款和应收账款
  • 年终一次性奖金个税计算
  • 重装系统后出现ctrl+alt+del
  • 给员工支付的房租费计入哪里?
  • 应付税款法账务处理
  • 现金流量科目怎么设置
  • win7系统打印机在哪里
  • xwizard.exe是什么
  • 房地产企业购地印花税如何入账
  • 三年以上的应付账款
  • 小刺猬 (© lorenzo104/Getty Images)
  • 处置长期股权投资产生的收益计入什么科目
  • node教程
  • ai当前的发展
  • nohup命令挂不上 每次都直接退出
  • dos命令怎么转到d盘
  • 出差补贴应该怎么入账
  • 发票作废怎么操作电脑上
  • 怎么把其他应收款的转到其他应付款
  • 什么不计入税金及附加
  • 服务费减免税款怎么算
  • java一天速成
  • php 迭代器
  • mysql数据库uuid
  • mongodb import
  • 暂估入账后续处理
  • 营业收入与利润总额的比值
  • 其它应付款的账户是什么
  • SQL Server 2008用'sa'登录失败,启用'sa'登录的解决办法
  • sql server 2005 sp4
  • mysql编程一般步骤
  • 季度销售额不超过30万元如何纳税
  • 资产减值准备怎么理解
  • 专项应付款如何核算
  • 委托加工物资的加工费计入什么科目
  • 酒店支付清洗费属于什么会计科目
  • 过路费抵扣进项税
  • mysql分页实现
  • 进程管理界面
  • Windows Server 2008之数据安全保护
  • linux命令和命令之间用
  • 如何解决焦虑的心理
  • 怎么备份和恢复goodnotes中的数据
  • xp怎么删除电脑系统
  • css中注释的写法
  • vue数组里面添加数组
  • jquery的使用方法
  • javascript怎么学
  • python excel库哪个好
  • 医院是自给自足吗
  • 退休军人免门票吗
  • 国税地税征管体制改革方案全文
  • 广东电子税务局官网登录入口手机版
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设