mysql 查询中文数据 我有张表数据量很大,name字段数据有中文的也有英文的,现在我想查出为中文的那些数据? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 如果要查找带中文的 可以用这个正则 [\x7f-\xff] SELECT NAME FROM BIAMING WHERE LIKE NAMe="";你那些中文有什么特点没,?戳,怎么识别中文和英文,求解?? 如果是想识别中文和英文,比较笨的方法是在表中加个字段记录当前记录name字段的编码格式,然后查找为gbk或是gb2312的。 SELECT name FROM table_name WHERE name regexp '[\x7f-\xff]' 你说这种,没用啊 你的 name 中是否存在中文和英文混合的情况? 我是问你在单个 name 中否存在中文和英文混合的情况 有没有mysql速度快的,又方便的? 嗯,utf8的不能用上面那个,那是gbk的,等我明天写个给你,也许待会楼下就有人给你了 先规范一下说法:这个"中文"虽然我们平时说意义很明确,不过到了电脑里就不那么清楚了....utf8里中文汉字是和韩文日文汉字放一起的,统称cjk...其实还包括一些全角的符号...utf8里汉字基本都在3字节区,有个别4字节的不过都是冷僻字,同时,3字节区里还有印度字啊什么的...因为你不会用到,也就都不管它们...所以我们简单化一点, 假设你是要找出所有带"3字节utf8字符"的记录那么可以用这个name regexp concat('[',char(0xE0),'-',char(0xEF),'][',char(0x80),'-',char(0xBF),'][',char(0x80),'-',char(0xBF),']')注意\xXX这样的写法没法在mysql里的正则里直接用,所以要用char和concat....google一下没找到更方便的方法...另外,不知道你数据里是否有2字节区的字符,(欧洲字符希腊字符拉丁字符等),如果确定没有....确定!!!就是说你数据里除了单字节的ascii字符,就是3字节的汉字....那么可以用一个简单的方法:char_length(name)!=length(name) mysql 的 REGEXP不是很强大, 试试 [^[:alnum:][:cntrl:][:space:]] char_length(name)!=length(name) 楼上这个很赞 PHP中留言板登陆后用户验证问题! 注册的时候 用问题验证 程序该怎么写 php zip扩展问题 谁知道新浪微博接口怎么搞,就是用新浪微博账号可以登录自己的网站。 请教ico如何能在IE上也能显示 如何使用php+apche+mysql构建一个中型网站 php连接Redis的问题 如何申请一个新的板块? 求助安装apache时80端口被占用的解决方案 ? #1045 - Access denied for user 'you'@'localhost' (using password: YES) 求一个完整好用的防跨站(过滤非法脚本)的函数 google checkout支付问题(php)
你那些中文有什么特点没,?
戳,怎么识别中文和英文,求解??
等我明天写个给你,也许待会楼下就有人给你了
这个"中文"虽然我们平时说意义很明确,不过到了电脑里就不那么清楚了....
utf8里中文汉字是和韩文日文汉字放一起的,统称cjk...其实还包括一些全角的符号...utf8里汉字基本都在3字节区,有个别4字节的不过都是冷僻字,
同时,3字节区里还有印度字啊什么的...因为你不会用到,也就都不管它们...所以我们简单化一点, 假设你是要找出所有带"3字节utf8字符"的记录那么可以用这个
name regexp concat('[',char(0xE0),'-',char(0xEF),'][',char(0x80),'-',char(0xBF),'][',char(0x80),'-',char(0xBF),']')注意\xXX这样的写法没法在mysql里的正则里直接用,所以要用char和concat....google一下没找到更方便的方法...
另外,不知道你数据里是否有2字节区的字符,(欧洲字符希腊字符拉丁字符等),
如果确定没有....确定!!!
就是说你数据里除了单字节的ascii字符,就是3字节的汉字....那么可以用一个简单的方法:
char_length(name)!=length(name)