视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL的SELECT技巧大全_MySQL
2020-11-09 17:29:55 责编:小采
文档

记录一些select的技巧:

  1、select语句可以用回车分隔

$sql="select * from article where id=1"

  和
$sql="select * from article
   where id=1"
,都可以得到正确的结果,但有时分开写或许能更明了一点,特别是当sql语句比较长时

  2、批量查询数据

  可以用in来实现

$sql="select * from article where id in(1,3,5)"

  3、使用concat连接查询的结果

$sql="select concat(id,"-",con) as res from article where id=1"

  返回"1-article content"

  4、使用locate

  用法:
select locate("hello","hello baby");
返回1

  不存在返回0

  5、使用group by

  以前一直没怎么搞明group by 和 order by,其实也满简单的,group by 是把相同的结果编为一组

exam:$sql="select city ,count(*) from customer group by city";

  这句话的意思就是从customer表里列出所有不重复的城市,及其数量(有点类似distinct)

  group by 经常与AVG(),MIN(),MAX(),SUM(),COUNT()一起使用

  6、使用having

  having 允许有条件地聚合数据为组

$sql="select city,count(*),min(birth_day) from customer
group by city having count(*)>10";

  这句话是先按city归组,然后找出city地数量大于10的城市

  btw:使用group by + having 速度有点慢

  同时having子句包含的表达式必须在之前出现过

  7、组合子句

  where、group by、having、order by(如果这四个都要使用的话,一般按这个顺序排列)

  8、使用distinct

  distinct是去掉重复值用的

$sql="select distinct city from customer order by id desc";

  这句话的意思就是从customer表中查询所有的不重复的city

  9、使用limit

  如果要显示某条记录之后的所有记录

$sql="select * from article limit 100,-1";

  10、多表查询

$sql="select user_name from user u,member m
where u.id=m.id and
m.reg_date>=2006-12-28
order by u.id desc"

  注意:如果user和member两个标同时有user_name字段,会出现mysql错误(因为mysql不知道你到底要查询哪个表里的user_name),必须指明是哪个表的

下载本文
显示全文
专题