位置: 编程技术 - 正文

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使用工具)

  • 塑料制品开票税率
  • 即征即退进项税额转出
  • 应交税费借方余额0.01怎么调整
  • 个人所得税代扣代缴手续费返还政策
  • 个人所得税如何做会计分录
  • 增值税影响利润总额吗
  • 算所得税要不要减去增值税
  • 年终奖是否列入社保基数
  • 所得税费用的余额期末时应转入利润分配账户
  • 社保按基数交工资按时发怎么做账
  • 2019年印花税税率多少
  • 权益法核算投资收益
  • 收到0税率的增值税发票
  • 营改增后哪些费用可以抵扣
  • 异地预缴企业所得税
  • 小规模纳税人发票可以抵扣吗
  • 失控发票进项税额转出申报表填写
  • 预缴企业所得税怎么做会计分录
  • 固定资产折旧方法可以变更吗
  • 公司股东认缴资质末到位导致公司破产应承担什么责任
  • 发票上月开本月到账要交企业所得税吗?
  • 亏损企业能否享受失业金
  • 汇算清缴专项附加扣除去年忘记填的能补填吗?
  • 旅游业小规模差额计税的能开1%
  • 运费用会计分录
  • 前任会计很多错账
  • win11打开图片
  • 苹果电脑如何查看内存大小
  • linux特殊权限设置
  • 分期付款购买的商品
  • 虎刺梅怎么养殖视频
  • PHP:mcrypt_enc_get_modes_name()的用法_Mcrypt函数
  • 转账支票购买办公用品会计
  • 劳务报酬怎么做帐
  • php memory_get_usage
  • 小企业会计准则财务报表至少包括
  • 微信支付扫码支付顺序
  • php遍历数组使用的是
  • python打印矩形方阵
  • js读取json配置文件
  • element级联选择器动态获取数据
  • 织梦技术论坛
  • 厂家给的返点怎么下往来账
  • mysql数据库死锁
  • 工会经费与残保金属于什么
  • 一张发票能分开做帐务处理吗?
  • 个体小企业怎么缴纳个人所得税
  • 工会经费的会计分录2022
  • 典当业销售的死当物品是什么意思
  • 增值税专用发票查询系统官方网站
  • 进项税转出怎么交税
  • 企业收到政府补助金80 000元,存入银行
  • 全额工资和实发工资
  • 年终奖会计怎么走账
  • 会计记账中借方和贷方
  • sql server复制表数据
  • mysql第二章
  • win8 win8.1
  • Win7笔记本怎么连接wifi
  • xp系统做完了进不去
  • linux系统的内存分配和回收采用什么算法?
  • react all in js
  • jquery源码分析笔记
  • 用bat实现定时执行任务的批处理文件
  • 右键隐藏在哪
  • 用javascript
  • node.js中的http.createServer方法使用说明
  • shell脚本运行linux命令
  • 基于javascript的毕业设计
  • [Unity3D]Unity3D游戏开发之塔防游戏项目讲解(上)
  • javascript的for循环
  • jQuery插件封装时如要实现链式编程,需要
  • jquery map遍历
  • 深圳国税服务
  • 现在是一般纳税人,属于小规模发生的业务怎么开票
  • 按期申报和按次申报的区别
  • 一般纳税人租赁费税率
  • 中建七局企业精神是什么
  • 出国海关申报单图片
  • 加油的增值税发票可以抵扣吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设