竹磬网-邵珠庆の日记 生命只有一次,你可以用它来做些更多伟大的事情–Make the world a little better and easier


144月/150

mysql 中文字段排序( 按拼音首字母排序) 的查询语句

发布在 邵珠庆

在处理使用Mysql时,数据表采用utf8字符集,使用中发现中文不能直接按照拼音排序

 

如果数据表tbl的某字段name的字符编码是latin1_swedish_ci

select * from `tbl` order by birary(name) asc ;

 

如果数据表tbl的某字段name的字符编码是utf8_general_ci

 

SELECT name FROM `tbl` WHERE 1 ORDER BY CONVERT( name USING gbk ) COLLATE gbk_chinese_ci ASC

 

===================

$orderby="convert(`group` USING gbk) COLLATE gbk_chinese_ci,displayorder,navid"

1511月/116

mysql批量删除指定前缀表,批量修改表名SQL语句

发布在 邵珠庆

  1. Select CONCAT( 'drop table ', table_name, ';' )  
  2. FROM information_schema.tables  
  3. Where table_name LIKE 'uc_%';  

注意: like ‘uc_%’ 其中 uc_是你需要替换的表前缀.
执行查询,会自动生成出 drop table table_name这样的SQL语句.
然后复制 drop语句 可以执行删除的操作了.

这么一来也可以安全的审核一下语句,避免误操作..

顺便补充一下一个批量修改表名的操作方法

  1. Select CONCAT( 'ALTER TABLE ', table_name, 'RENAME TO ', table_name,';' )  
  2. FROM information_schema.tables  
  3. Where table_name LIKE 'uc_%';  

下面这种代码是今天遇到的,表头前面是 db,但是没有下横线显得很乱,于是批量将”dbtable_name”改成”db_table_name”
主要用的函数是mysql的substring函数

mysql教程 substring 字符截取函数
substring(str,pos)语法

substring(filed,m):截取filed字段从第m个字符开始到结束的字符串;

substring(filed,m,n):截取filed字段从第m个字符开始的长度为n的字符串;

str,字符

pos,从第几个开始取

  1. Select CONCAT( 'ALTER TABLE ', table_name, 'RENAME TO db_'substring(table_name,3),';' )  
  2. FROM information_schema.tables  
  3. Where table_name LIKE 'db%';  

会得到结果

  1. ALTER TABLE uc_aaa RENAME TO uc_aaa;  
  2. ALTER TABLE uc_bbb RENAME TO uc_bbb;  

批量复制一下到记事本或者 et之类的编辑工具中,然后批量替换 RENAME TO uc 成 RENAME TO 你想要的表前缀
完成后 再执行.

这样就完成了表名的批量修改拉…