博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mysql增删改查基础sql语句
阅读量:3947 次
发布时间:2019-05-24

本文共 4890 字,大约阅读时间需要 16 分钟。

1、“增”——添加数据

语法:INSERT INTO 表名 (字段名1,字段名2,…) VALUES (值1,值2,…):

举例:

INSERT INTO student(id,name,grade) VALUES(1,'zhangshan',98);

同时添加多条数据

语法:INSERT INTO 表名 (字段名1,字段名2,…) VALUES (值1,值2,…),(值1,值2,…),…;

举例:

INSERT INTO student VALUES (5,‘lilei’,99),(6,'hanmeimei',87),(8,'poly',76);

2、“删”——删除数据

语法:DELETE FROM 表名 WHERE 条件表达式

举例:

DELETE FROM student WHERE id='7';

3、“改”——更新数据

语法:UPDATE 表名 SET 字段名1=值1,字段名2=值2,… WHERE 条件表达式 ;

举例:

UPDATE student SET name=‘caocao’,grade=50 WHERE id=1;

4、“查”——之单表查询

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

举例:

SELECT id,name FROM student;

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

语法:SELECT * FROM 表名;

4.2 带关系运算符的查询

语法:SELECT 字段名1,字段名2,… FROM 表名 WHERE 条件表达式

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

关系运算符说明

= 等于
!= 不等于
< 小于
<= 小于等于
> 大于
>= 大于等于

4.3 带 IN 关键字的查询

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

语法:SELECT * | 字段名1,字段名2,… FROM 表名 WHERE 字段名 [ NOT ] IN (元素1,元素2,…)

举例:

SELECT * FROM student2 WHERE id IN (1,2,3);

4.4 带 BETWEEN AND 关键字的查询

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

语法:SELECT 字段名1,字段名2,… FROM 表名 WHERE 字段名 [ NOT ] BETWEEN 值1 AND 值2;

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

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

4.5 空值查询

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

语法:SELECT * | 字段名1,字段名2,… FROM 表名 WHERE 字段名 IS [ NOT ] NULL

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

SELECT * FROM student2 WHERE gender IS NULL;

4.6 带 DISTINCT 关键字的查询

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

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

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

SELECT DISTINCT gender FROM student2;

4.7 带 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)下划线(_)通配符

下划线通配符只匹配单个字符,若要匹配多个字符,需要使用多个下划线通配符。例如,字符串“ 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';

4.8 带 AND 关键字的多条件查询

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

语法:SELECT * 字段名1,字段名2,… FROM 表名 WHERE 条件表达式1 AND 条件表达式2 [ … AND 条件表达式 n ];

举例:查询student2表中 id 字段小于5,并且 gender 字段值为“ 女 ”的人的id和name

SELECT id,name FROM student2 WHERE id<5 AND gender='女';

4.9 带 OR 关键字的多条件查询

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

语法:SELECT * 字段名1,字段名2,… FROM 表名 WHERE 条件表达式1 OR 条件表达式2 [ … OR 条件表达式 n ];

举例:查询student2表中 id 字段小于3,或者 gender 字段值为“ 女 ”的人的id,name和gender

SELECT id,name ,gender FROM student2 WHERE id<3 OR gender='女';

4.10 升序、降序

语法:

升序:select * from 表名 order by 表中的字段 asc(mysql中默认是升序排列,可不写)
降序:select * from 表名 order by 表中的字段 desc

若要进行同时一个升序,一个降序,则如下:

order by 升序字段 asc,降序字段 desc。

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

SELECT * FROM student2 ORDER BY grade;

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

SELECT * FROM student2 ORDER BY grade DESC;

5、高级查询

5.1 聚合函数

函数名称 作用
COUNT() 返回某列的行数
SUM() 返回某列值的和
AVG() 返回某列的平均值
MAX() 返回某列的最大值
MIN() 返回某列的最小值

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

语法:SELECT COUNT(*) FROM 表名

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

SELECT COUNT(*) FROM student2;

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

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

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

SELECT SUM(grade) FROM student2;

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

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

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

SELECT AVG(grade) FROM student2;

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

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

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

SELECT MAX(grade) FROM student2;

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

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

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

SELECT MIN(grade) FROM student2;

5.2 分组查询

在对表中数据进行统计的时候,可以使用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)GROUP 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;

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

语法:SELECT 字段名2,字段名2,… FROM 表名 LIMIT [ OFFSET ,] 记录数

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

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

SELECT * FROM student LIMIT 4;

为表和字段取别名

5.4 为表取别名

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

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

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

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

5.5 为字段取别名

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

举例:查询student2表中的所有记录的name和gender字段值,并未这两个字段起别名stu_name和stu_gender

SELECT name AS stu_name,gender AS stu_gender FROM student2;

转载地址:http://vthwi.baihongyu.com/

你可能感兴趣的文章
Call Setting中的Line Switch功能作用
查看>>
GPS数据解析
查看>>
The top 6 programming languages for IoT projects
查看>>
67 open source tools and resources for IoT
查看>>
蓝牙低功耗(BLE)应用领域
查看>>
nRF51822低功耗睡眠函数应用
查看>>
Android 语言码_国家码
查看>>
从iphone和android应用来看公司
查看>>
android 修改代码怎样编译
查看>>
领导者如何增强说服力
查看>>
比金钱更好的十样东西
查看>>
凡事必定不少于三个以上的解决方法
查看>>
带团队的点滴心经
查看>>
五种力量让你如虎添翼
查看>>
你害怕创新吗
查看>>
创新服务的七要素
查看>>
虚伪的奉承也有效
查看>>
蒂姆·库克的五项核心领导力
查看>>
你为何没有成为领导者
查看>>
一切悲剧都源于不当激励
查看>>