A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© hy03030816 初级黑马   /  2019-8-14 15:12  /  1266 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

* select * from 表名;

1. 语法:
        select
                字段列表
        from
                表名列表
        where
                条件列表
        group by
                分组字段
        having
                分组之后的条件
        order by
                排序
        limit
                分页限定


2. 基础查询
        1. 多个字段的查询
                select 字段名1,字段名2... from 表名;
                * 注意:
                        * 如果查询所有字段,则可以使用*来替代字段列表。
        2. 去除重复:
                * distinct
        3. 计算列
                * 一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)
                * ifnull(表达式1,表达式2):null参与的运算,计算结果都为null
                        * 表达式1:哪个字段需要判断是否为null
                        * 如果该字段为null后的替换值。
        4. 起别名:
                * as:as也可以省略
               

3. 条件查询
        1. where子句后跟条件
        2. 运算符
                * > 、< 、<= 、>= 、= 、<>
                * BETWEEN...AND  
                * IN( 集合)
                * LIKE:模糊查询
                        * 占位符:
                                * _:单个任意字符
                                * %:多个任意字符
                * IS NULL  
                * and  或 &&
                * or  或 ||
                * not  或 !
               
                        -- 查询年龄大于20岁

                        SELECT * FROM student WHERE age > 20;
                       
                        SELECT * FROM student WHERE age >= 20;
                       
                        -- 查询年龄等于20岁
                        SELECT * FROM student WHERE age = 20;
                       
                        -- 查询年龄不等于20岁
                        SELECT * FROM student WHERE age != 20;
                        SELECT * FROM student WHERE age <> 20;
                       
                        -- 查询年龄大于等于20 小于等于30
                       
                        SELECT * FROM student WHERE age >= 20 &&  age <=30;
                        SELECT * FROM student WHERE age >= 20 AND  age <=30;
                        SELECT * FROM student WHERE age BETWEEN 20 AND 30;
                       
                        -- 查询年龄22岁,18岁,25岁的信息
                        SELECT * FROM student WHERE age = 22 OR age = 18 OR age = 25
                        SELECT * FROM student WHERE age IN (22,18,25);
                       
                        -- 查询英语成绩为null
                        SELECT * FROM student WHERE english = NULL; -- 不对的。null值不能使用 = (!=) 判断
                       
                        SELECT * FROM student WHERE english IS NULL;
                       
                        -- 查询英语成绩不为null
                        SELECT * FROM student WHERE english  IS NOT NULL;



                        -- 查询姓马的有哪些? like
                        SELECT * FROM student WHERE NAME LIKE '马%';
                        -- 查询姓名第二个字是化的人
                       
                        SELECT * FROM student WHERE NAME LIKE "_化%";
                       
                        -- 查询姓名是3个字的人
                        SELECT * FROM student WHERE NAME LIKE '___';
                       
                       
                        -- 查询姓名中包含德的人
                        SELECT * FROM student WHERE NAME LIKE '%德%';


0 个回复

您需要登录后才可以回帖 登录 | 加入黑马