MySQL 常用SQL语句(持续更新中...)

一、查询技巧
  • 1、在学生表中,查询重名的学生及记录数,则SQL如下
select name, count(*) as count 
from fa_student 
group by name 
having count > 1
  • 2、排序函数field(),
    是将查询的结果集按照指定顺序排序。
    格式:FIELD(str,str1,str2,str3,…)
    解释:str是字段名,str1、str2、str3都是该字段的具体值。
    详细解析:字段str按照字符串str1,str2,str3的顺序返回查询到的结果集。如果表中str字段值不存在于str1,str2,str3中的记录,则放在结果集最前面返回,倒序,正反之。
    举例:数据表order中有字段status,按照status自定义排序方式进行排序
SELECT id, status from mall_local_order order by field(status, 0,5,4,1,2)
  • 3、字符串拼接函数concat(str1,str2,str3,…)
  • 4、借助子查询得出的结果进行相加或相减等操作
SELECT
	id,nickname,
	(select count(*) from mall_user a1 where FIND_IN_SET(a.id,a1.path) and del_flag = 0) as team_count,
	(select count(*) from mall_user a1 where a1.spread_uid = a.id and del_flag = 0) as spread_count,
	(select team_count - spread_count) as spread_team_count -- 加个select关键字即可
FROM
	mall_user a
二、设置技巧
  • 1、设置主键自增起始值
ALTER TABLE table_name  AUTO_INCREMENT = 10000
  • 2、如果某表的字符集是utf8,或者表中字段是utf8时,通过下面sql可以将该表及表中varchar字段改为utf8mb4,方便存储表情符号
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4  COLLATE utf8mb4_general_ci
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值