• mysql数据库的查询


    1“查”——之单表查询

            INSERT INTO student2(name,grade,gender)

            VALUES ('songjiang',40,'男'),('wuyong',100,'男'),('qinming',90,'男'),('husanniang',88,'女'),('sunerniang',66,'女'),('wusong',86,'男'),('linchong',92,'男'),('yanqing',90,NULL);

      

    注意:若因为此处插入的数据包含了中文而导致无法插入,可将“男/女”改为“man/woman”,或者将字段编码改为utf-8(方法自行百度,此处不做讲解)。

    1.1  简单查询

    1.1.1  查询所有字段

    语法:SELECT 字段名1,字段名2

       FROM 表名

    举例:查询student2表中的所有记录

    命令:SELECT id,name,grade ,gender

          FROM student2;

    果:

     

    注意:字段顺序可以更改,如:

        SELECT id,grade,gender ,name

            FROM student2;

    则显示的结果也会作出对应的调整:

     

     

    1.1.2  SELECT语句中使用(‘ * ’)通配符代替所有字段

    语法:SELECT * FROM 表名;

     在此前已多次使用此命令,所以此处不作赘述。

     

     

    1.1.3  查询指定的部分字段

    语法:SELECT 字段名1,字段名2… FROM 表名;

    举例:查询student2表中的name字段和gender字段

    命令:SELECT name,gender FROM student2;

     结果:

     

     

    从结果中可以看到只显示了namegender两个字段。

    1.2   按条件查询

    1.2.1  带关系运算符的查询

     语法:SELECT 字段名1,字段名2

        FROM 表名

          WHERE 条件表达式

    WHERE子句中可以使用如下关系运算符:

    关系运算符

    说        明

        =

        等于

        <>

        不等于

        !=

        不等于

        <

        小于

        <=

        小于等于

        >

        大于

        >=

        大于等于

    举例:查询student2表中id4的人的idname字段

    命令:SELECT idname FROM student2  WHERE id=4;

    结果:

     

     

    不等于<>

     

     

     

     

    举例:查询student2表中grade大于80的人的namegrade字段

    命令:SELECT name FROM student2 WHERE grade>80;

    结果:

     

    1.2.2  带 IN 关键字的查询

    IN关键字用于判断某个字段的值是否在指定集合中,若在,则该字段所在的记录将会被查询出来.

    语法:SELECT * | 字段名1,字段名2

       FROM 表名

       WHERE 字段名 [ NOT ]  IN (元素1,元素2

    举例:查询student2表中id值为1,2,3的记录

    命令:SELECT * FROM student2 WHERE  id IN 1,2,3);

    结果:

     

     

    注意:NOT IN IN 相反,查询的是不在指定范围内的记录。

     

    1.2.3  带 BETWEEN AND  关键字的查询

    BETWEEN AND 用于判断某个字段的值是否在指定范围之内,若在,则该字段所在的记录会被查询出来,反之不会。

    语法:SELECT * | { 字段名1,字段名2… }

       FROM  表名

          WHERE 字段名 [ NOT ] BETWEEN  1  AND  2

    举例:查询student2表中id值在2~5之间的人的idname

    命令:SELECT id,name FROM students WHERE id BETWEEN 2 AND 5;

    结果:

     

     

    注意:NOT BETWEEN AND 表示查询指定范围外的记录。

     

    1.2.4  空值查询

    在数据表中有些值可能为空值(NULL),空值不同于0,也不同于空字符串,需要使用 IS NULL 来判断字段的值是否为空值。

    语法:SELECT * | 字段名1,字段名2

       FROM 表名

       WHERE 字段名 IS [ NOT ] NULL

    举例:查询student2表中gender值为空值的记录。

    命令:SELECT * FROM student2 WHERE gender IS NULL;

     结果:

     

    注意:IS NOT NULL 关键字用来查询字段不为空值的记录。

     

     

    1.2.5  DISTINCT 关键字的查询

    很多表中某些字段的数据存在重复的值,可以使用DISTINCT关键字来过滤重复的值,只保留一个值。

    语法:SELECT DISTINCT 字段名 FROM 表名;

    举例:查询student2表中gender字段的值,结果中不允许出行重复的值。

    命令:SELECT DISTINCT gender FROM student2;

    结果:

     

     

    注意:DISTINCT 关键字还可作用于多个字段,则只有多个字段的值都完全相同时才会被认作是重复记录。

    1.2.6  带 LIKE 关键字的查询

    语法:SELECT * | 字段名1,字段名2

       FROM 表名

       WHERE 字段名 [ NOT ] LIKE ‘匹配字符串’;

    1)百分号(%)通配符

    匹配任意长度的字符串,包括空字符串。例如,字符串“ c% ”匹配以字符 c 开始,任意长度的字符串,如“ ct  ”“ cut ”“ current ”等;字符串“ c%g ”表示以字符 c 开始,以 g 结尾的字符串;字符串“ %y% ”表示包含字符“ y ”的字符串,无论“ y ”在字符串的什么位置。

    举例1查询student2表中name字段以字符“ s ”开头的人的id,name

    命令:SELECT id,name FROM student2  WHERE name LIKE "S%"; 

    结果:

     

     

    举例2:查询student2表中name字段以字符“ w ”开始,以字符“ g ”结尾的人的idname

    命令:SELECT id,name FROM student2 WHERE name LIKE 'w%g';

    结果:

     

     

    举例3:查询student2表中name字段不包含“ y ”的人的idname

    命令:SELECT id,name FROM student2 WHERE name NOT LIKE '%y%';

    结果:

     

    2)下划线(_)通配符

     下划线通配符只匹配单个字符,若要匹配多个字符,需要使用多个下划线通配符。例如,字符串“ cu_ ”匹配以字符串“ cu ”开始,长度为3的字符,如“ cut ”“ cup ”;字符串“ c__l”匹配在“ c ”“ l ”之间包含两个字符的字符串,如“ cool ”。需要注意的是,连续的“_”之间不能有空格,例如“M_ _QL”只能匹配“My SQL”,不能匹配“MySQL”

    举例:查询在student2表中name字段值以“ wu ”开始,以“ ong ”结束,并且中间只有一个字符的记录。

    命令:SELECT * FROM student2 WHERE name LIKE 'wu_ong';

    结果:

     

    注意:若要查询的字段值本来就含有“ % ”或者“ _ ”,则要用“ ”进行转义,如要查询本身含有“ % ”的字符串,命令应改为 “ %\%%”

    1.2.7  AND 关键字的多条件查询

    在使用SELECT语句查询数据时,优势为了使查询结果更加精确,可以使用多个查询条件,如使用 AND 关键字可以连接两个或多个查询条件。

    语法:SELECT * | 字段名1,字段名2

       FROM 表名

       WHERE 条件表达式1 AND 条件表达式2 [ … AND 条件表达式 n ];

    举例:查询student2表中 id 字段小于5,并且 gender 字段值为的人的idname

    命令:SELECT id,name FROM student2 WHERE id<5 AND gender='';

    结果:

     

     

    1.2.8  OR 关键字的多条件查询

    AND 关键字不同,OR 关键字只要满足任意一个条件就会被查询出来

    语法:SELECT * | 字段名1,字段名2

       FROM 表名

       WHERE 条件表达式1 OR 条件表达式2 [ … OR 条件表达式 n ];

    举例:查询student2表中 id 字段小于3,或者 gender 字段值为的人的idnamegender

    命令:SELECT id,name ,gender FROM student2 WHERE id<3 OR gender='';

    结果:

     

     

    1.2.9   OR AND 一起使用的情况

    OR AND 一起使用的时候,AND 的优先级高于 OR,因此二者一起使用时,会先运算 AND 两边的表达式,再运算 OR 两边的表达式。

    举例:查询student2表中gender值为或者gender值为并且grade字段值为100的人的记录

    命令:SELECT * FROM student2 WHERE gender='' OR gender='' AND grade=100;

    结果:

     

     1.3  高级查询

    1.3.1  聚合函数

      函数名称

    作用

        COUNT()

        返回某列的行数

        SUM()

        返回某列值的和

        AVG()

        返回某列的平均值

        MAX()

        返回某列的最大值

        MIN()

        返回某列的最小值

    1)COUNT()函数:统计记录的条数

    语法:SELECT COUNT(*) FROM 表名

    举例:查询student2表中一共有多少条记录

    命令:SELECT COUNT(*) FROM student2;

    结果:

     

     

    2SUM()函数:求出表中某个字段所有值的总和

    语法:SELECT  SUM(字段名) FROM 表名;

    举例:求出student2表中grade字段的总和

    命令:SELECT SUM(grade) FROM student2;

    结果:

     

     

    3AVG()函数:求出表中某个字段所有值的平均值

    语法:SELECT AVG(字段名) FROM 表名;

    举例:求出student2表中grade字段的平均值

    命令:SELECT AVG(grade) FROM student2;

    结果:

     

     

    4MAX()函数:求出表中某个字段所有值的最大值

    语法:SELECT MAX(字段名) FROM 表名;

    举例:求出student2表中所有人grade字段的最大值

    命令:SELECT MAX(grade) FROM student2;

    结果:

     

    5MIN()函数:求出表中某个字段所有值的最小值

    语法:SELECT MIN(字段名) FROM 表名;

    举例:求出student2表中所有人grade字段的最小值

    命令:SELECT MIN(grade) FROM student2;

    结果:

     

     

     

    1.3.2  对查询结果进行排序

    语法:SELECT 字段名1,字段名2

       FROM 表名

       ORDER BY 字段名1 [ ASC | DESC ],字段名2 [ ASC | DESC ]…

    在该语法中指定的字段名是对查询结果进行排序的依据,ASC表示升序排列,DESC 表示降序排列,默认情况是升序排列。

    举例1:查出student2表中的所有记录,并按照grade字段进行升序排序

    命令:SELECT * FROM student2

       ORDER BY grade;

    结果:

     

    举例2:查出student2表中的所有记录,并按照grade字段进行降序排序

    命令:SELECT * FROM student2

       ORDER BY grade DESC;

    结果:

     

    1.3.3  分组查询

    在对表中数据进行统计的时候,可以使用GROUP BY 按某个字段或者多个字段进行分组,字段中值相同的为一组,如男生分为一组,女生分为一组。

    语法:SELECT  字段名1,字段名2

       FROM 表名

       GROUP BY 字段名1,字段名2… [ HAVING 条件表达式 ];

    1)单独使用 GROUP BY 进行分组

    单独使用GROUP BY 关键字,查询的是每个分组中的一条记录

    举例:查询student2表中的数据,按照gender字段进行分组。

    命令:SELECT * FROM student2 GROUP BY gender;

    结果:

     

    注意:若在此2例中键入命令之后出现“#1055”错误,无法完成分组查询,是由于MySQL版本升级到了5.7,可自行百度“MySQL 1055错误参考解决办法。

    2GROUP BY 和聚合函数一起使用

    GROUP BY 和聚合函数一起使用,可以统计出某个或者某些字段在一个分组中的最大值、最小值、平均值等。

    举例:将student2表按照gender字段进行分组查询,计算出每组共有多少个人。

    命令:SELECT COUNT(*) ,gender FROM student2 GROUP BY gender;

    结果:

     

     

    2GROUP BY HAVING 关键字一起使用

     HAVING关键字和WHERE关键字的作用相同,区别在于HAVING 关键字可以跟聚合函数,而WHERE 关键字不能。通常HAVING 关键字都和GROUP BY一起使用,用于对分组后的结果进行过滤。

    举例:将student2表按照gender字段进行分组查询,查询出grade字段值之和小于300的分组

    命令:SELECT sum(grade),gender FROM student2 GROUP BY gender HAVING SUM(grade) < 300;

    结果:

     

    1.3.4  使用 LIMIT 限制查询结果的数量

    语法:SELECT 字段名2,字段名2

       FROM 表名

       LIMIT [ OFFSET ,] 记录数

    在此语法中,LIMIT 后面可以跟两个参数,第一个参数“ OFFSET ”表示偏移量,如果偏移量为0,则从查询结果的第一条记录开始,偏移量为1则从查询结果中的第二条记录开始,以此类推。OFFSET为可选值,默认值为0,第二个参数记录数表示指定返回查询记录的条数。

    举例1:查询student2表中的前四条记录。

    命令:SELECT * FROM student LIMIT 4;

    结果:

               

    举例2:查询student2表中grade字段从第五位到第八位的人(从高到低)

    命令:SELECT * FROM student2 ORDER BY grade DESC LIMIT 4,4;

    结果:

     

    1.4.1 为表取别名

    在进行查询操作时,如果表名很长使用起来不方便,可以为表取一个别名来代替表的名称。

    语法:SELECT * FROM 表名 [ AS ] 别名;

    举例:为student2表起一个别名s,并查询student2表中gender字段值为“女”的记录

    命令:SELECT * FROM student2 AS s WHERE s.gender='女';

    结果:

     

    1.4.1 为字段取别名

    语法:SELECT 字段名 [ AS ] 别名 [ ,字段名 [AS] 别名,…]  FROM 表名 ;

    举例:查询student2表中的所有记录的namegender字段值,并未这两个字段起别名stu_namestu_gender

    命令:SELECT name AS stu_name,gender AS stu_gender FROM student2;

    结果:

     

  • 相关阅读:
    python初级 0 出发吧
    10 个免费的服务器监控工具推荐
    Nginx 的线程池与性能剖析
    Java中 Comparator接口 与Comparable 的区别
    ORACLE分区表、分区索引详解
    搜索引擎爬虫蜘蛛的USERAGENT大全
    ios和android的发展前景比较
    DES、3DES、AES加密方式
    jsp、freemarker、velocity区别详解
    面向对象五大原则(SRP、OCP、LSP、DIP、ISP)
  • 原文地址:https://www.cnblogs.com/yang1182/p/9555251.html
Copyright © 2020-2023  润新知