sql查询

作者: 往你头上敲三下 | 来源:发表于2018-07-03 21:56 被阅读0次

    1.查询一张表:     select * from 表名;

    2.查询指定字段:select 字段1,字段2,字段3....from 表名;

    3.where条件查询:select字段1,字段2,字段3 frome 表名 where 条件表达式;

    例:select * from t_studect where id=1;

           select * from t_student where age>22;

    4.带in关键字查询:select 字段1,字段2 frome 表名 where 字段 [not]in(元素1,元素2);

    例:select * from t_student where age in (21,23);

           select * from t_student where age not in (21,23);

    IN 与 = 的异同

     相同点:均在WHERE中使用作为筛选条件之一、均是等于的含义

     不同点:IN可以规定多个值,等于规定一个值

    5.带between and的范围查询:select 字段1,字段2 frome 表名 where 字段 [not]between 取值1 and 取值2;

    例:select * frome t_student where age between 21 and 29;

           select * frome t_student where age not between 21 and 29;

    6.带like的模糊查询:select 字段1,字段2... frome 表名 where 字段 [not] like '字符串';

    '%a'    //以a结尾的数据

    'a%'    //以a开头的数据

    '%a%'    //含有a的数据

    ‘_a_’    //三位且中间字母是a的

    '_a'    //两位且结尾字母是a的

    'a_'    //两位且开头字母是a的

    LIKE'[CK]ars[eo]n' 将搜索下列字符串:Carsen、Karsen、Carson 和 Karson(如 Carson)。

    LIKE'[M-Z]inger' 将搜索以字符串 inger 结尾、以从 M 到 Z 的任何单个字母开头的所有名称(如 Ringer)。

    LIKE'M[^c]%' 将搜索以字母 M 开头,并且第二个字母不是 c 的所有名称(如MacFeather)。

    例:select * frome t_student where stuName like '张三'';

           select * frome t_student where stuName like '张三%'';

           select * frome t_student where stuName like '%张三%'';//含有张三的任意字符

           select * frome t_student where stuName like '张三_''

    7.空值查询:select 字段1,字段2...frome 表名 where 字段  is[not] null;

    8.带and多条件查询:

    select 字段1,字段2...frome 表名 where 条件表达式1 and 条件表达式2 [and 条件表达式n]

    例:select * frome t_student where gradeName='一年级' and age=23;

    9.带or的多条件查询

    select 字段1,字段2...frome 表名 where 条件表达式1 or 条件表达式2 [or 条件表达式n]

    例:select * frome t_student where gradeName='一年级' or age=23;//或者,条件只要满足一个

    10.distinct去重复查询:select distinct 字段名 from 表名;

    11.对查询结果排序order by:select 字段1,字段2...from 表名 order by 属性名 [asc|desc]

    例:select * frome t_student order by age desc;//降序,从大到小

           select * frome t_student order by age asc;//升序,asc默认可以不写

    12.分组查询group by

    group by 属性名 [having 条件表达式][with rollup]

    1.单独使用(毫无意义,不能单独使用);

    2.与group_concat()函数一起使用

    select gradeName,group_count(stuName)from t_student group by gradeName;

    yu

    3.与聚合函数一起使用

    select gradeName,count(stuName) from t_student group by gradeName;

    4.与having一起使用(显示输出结果)

    在一个查询中,HAVING 子句必须放在 GROUP BY 子句之后, ORDER BY 子句之前

    5.与with rollup 一起使用(最后加入一个总和行)

    select gradeName,group_concat(stuName) from t_student groupName with rollup;

    13.limit分页查询

    select * from t_student limit 0,2 offset 5;需要从一个特定的偏移开始提取记录。从第三位开始提取 5个记录,

    select * from t_student limit 6;提取前6行数据

    相关文章

      网友评论

          本文标题:sql查询

          本文链接:https://www.haomeiwen.com/subject/cmxsuftx.html