当前位置:  数据库>mysql

让MySQL支持中文排序的实现方法

    来源: 互联网  发布时间:2014-09-06

    本文导语:  让MySQL支持中文排序 编绎MySQL时一般以ISO-8859字符集作为默认的字符集,因此在比较过程中中文编码字符大小写转换造成了这种现象,一种解决方法是对于包含中文的字段加上"binary"属性,使之作为二进制比较,例如将"name char(10...

让MySQL支持中文排序

编绎MySQL时一般以ISO-8859字符集作为默认的字符集,因此在比较过程中中文编码字符大小写转换造成了这种现象,一种解决方法是对于包含中文的字段加上"binary"属性,使之作为二进制比较,
例如将"name char(10)"改成"name char(10)binary"。
编译MySQL时使用--with--charset=gbk 参数,这样MySQL就会直接支持中文查找和排序了。

mysql order by 中文 排序

在MySQL中,我们经常会对一个字段进行排序查询,但进行中文排序和查找的时候,对汉字的排序和查找结果往往都是错误的。 这种情况在MySQL的很多版本中都存在。
如果这个问题不解决,那么MySQL将无法实际处理中文。 出现这个问题的原因是因为MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认的字符集,因此在比较过程中中文编码字符大小写转换造成了这种现象。
解决方法:
对于包含中文的字段加上"binary"属性,使之作为二进制比较,例如将"name char(10)"改成"name char(10)binary"。
如果你使用源码编译MySQL,可以编译MySQL时使用 --with--charset=gbk 参数,这样MySQL就会直接支持中文查找和排序了(默认的是latin1)。也可以用 extra-charsets=gb2312,gbk 来加入多个字符集。
如果不想对表结构进行修改或者重新编译MySQL,也可以在查询语句的 order by 部分使用 CONVERT 函数。比如 select * from mytable order by CONVERT(chineseColumnName USING gbk);

UTF8 默认校对集是 utf8_general_ci , 它不是按照中文来的。你需要强制让MySQL按中文来排序。

select * from core_vender_info order by convert(vender_abbrev USING gbk) COLLATE gbk_chinese_ci

    
 
 

您可能感兴趣的文章:

  • mysql中文排序注意事项与实现方法
  • mysql 按中文字段排序
  • apache+tomcat3.2.3+mm.mysql+mysql3.22+jdk1.3.1中文问题,急!!!!分不够还可以再加..
  • DOS命令行窗口mysql中文显示乱码问题解决方法
  • Apache 1.3.22/Tomcat 4.0.4/Mysql 3.23/mm.mysql.jdbc-2.0pre5的中文乱码问题
  • mysql query browser中文乱码的解决方法
  • mysql 不能插入中文问题
  • cmd中MySQL中文数据乱码问题解决方法
  • mysql 客户端不能输入中文?
  • windows环境下Mysql中文乱码问题解决方法
  • jsp中文乱码 jsp mysql 乱码的解决方法
  • 解决php csv文件导入mysql中文乱码
  • 解决mysql不能插入中文Incorrect string value
  • mysql的中文问题
  • 解析Hibernate + MySQL中文乱码问题
  • C# mysql 插入数据,中文乱码的解决方法
  • mysql odbc字符集设置(中文显示乱码)
  • 我在安装LINUX 9简体中文版时,漏装了一个PHP-MYSQL的模块,那我现在该如何加装?
  • JBuilder中用MYSQL数据库,用中文进行条件查询时,查不出任和数据?
  • mysql导出导入中文表解决方法
  • 数据库查询排序使用随机排序结果示例(Oracle/MySQL/MS SQL Server)
  • mysql自定义排序顺序语句
  • mysql如何根据汉字首字母排序
  • MYSQL 关于两个经纬度之间的距离由近及远排序
  • Mysql select in 按id排序实现方法
  • mysql的中文数据按拼音排序的2个方法
  • mysql如何按照中文排序解决方案
  • mysql 关键词相关度排序方法详细示例分析
  • MySQL查询优化:连接查询排序浅谈
  • MySQL查询优化:连接查询排序limit(join、order by、limit语句)介绍
  • 说说mysql查询优化中的连接查询排序
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Thinkphp实现MySQL读写分离操作示例
  • MySQL实现类似Oracle中的decode()函数的功能
  • linux+free_radius+mysql能否实现多重认证?
  • 使用dreamhost空间实现MYSQL数据库备份方法
  • 如何实现JSP与mysql的连接?
  • 详解MySQL中DROP,TRUNCATE 和DELETE的区别实现mysql从零开始
  • mysql 选择插入数据(包含不存在列)具体实现
  • 请问,如何在windows的环境下,实现jsp和mysql的连接?
  • mysql数据库添加用户及分配权限具体实现
  • mysql实现根据多个字段查找和置顶功能
  • MySQL 查询结果以百分比显示简单实现
  • 简单实现SQLServer转MYSQL的方法
  • 在MySQL如何实现如:select top 2 * from board; 这样的提取前N条记的功能?
  • MySql实现跨表查询的方法详解
  • MySQL 一次执行多条语句的实现及常见问题
  • php下巧用select语句实现mysql分页查询
  • mysql 触发器实现两个表的数据同步
  • ●●●遇到难题,请高手指点,lvs双mail,mai用户在一台mysql上,实现多台mail轮流工作●●
  • MySQL单表多关键字模糊查询的实现方法
  • 利用Shell脚本实现远程MySQL自动查询
  • mysql中如何查看最大连接数(max_connections)和修改最大连接数
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • Mysql查询错误:ERROR:no query specified原因
  • MySQL 重装MySQL后, mysql服务无法启动
  • php安装完成后如何添加mysql扩展
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • 求解释: useradd -g mysql mysql -d /home/mysql -s /sbin/nologin
  • MySQL Workbench的下载安装与使用教程


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    博客 iis7站长之家