MySQL语句

 

1.1.1 INSERT 语句中指定所有字段名

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

1.1.2 INSERT语句中不指定字段名

  INSERT INTO student  VALUES (2,'lisi',62);

1.2 为表的指定字段添加数据

  INSERT INTO student(id,name)   VALUES(3,'wangwu');

1.3 INSERT语句的其他写法

  INSERT INTO student SET id=4,name='zhaoliu',grade=72;

 1.4  同时添加多条数据

  INSERT INTO 表名[(字段名1,字段名2,…)] VALUES (值1,值2,…),(值1,值2,…),  …(值1,值2,…)

 

2、“删”——删除数据

2.1 删除部分数据

  DELETE  FROM student  WHERE id=7;

2.2 删除全部数据

  DELETE FROM student;

2.2 删除全部数据的另一种方法——TRUNCATE

  语法:TRUNCTE [TABLE ] 表名

  举例:TRUNCATE TABLE student;即可删除student表

  注意:

  (1)DELETE 后面可以跟WHERE子句指定删除部分记录,TRUNCATE只能删除整个表的所有记录

(2)使用TRUNCATE语句删除记录后,新添加的记录时,自动增长字段(如本文中student表中的 id 字段)会默认从1开始,而使用DELETE删除记录后,新添加记录时,自动增长字段会从删除时该字段的的最大值加1开始计算(即原来的id最大为5,则会从6开始计算)。所以如果是想彻底删除一个表的记录而且不会影响到重新添加记录,最好使用TRUNCATE来删除整个表的记录。

3、“改”——更新数据

 

3.1  UPDATE 更新部分数据

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

3.2  字段部分内容替换

  UPDATE 表名 SET recode = REPLACE(recode,"_","-") WHERE recode LIKE "%_%"

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

4.2   按条件查询

4.2.1  带关系运算符的查询

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

    FROM 表名

      WHERE 条件表达式

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

4.2.2关系运算符

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

 


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

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

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

 

4.2.3   BETWEEN AND与NOT BETWEEN AND 

  SELECT * | { 字段名1,字段名2,… }FROM  表名  WHERE 字段名 [ NOT ] BETWEEN  值1  AND  值2;

4.2.4  空值查询

  SELECT * FROM student2 WHERE gender IS NOT NULL;

 

4.2.5  DISTINCT (去重)

  SELECT DISTINCT gender FROM student2;

4.2.6  带 LIKE 关键字的查询

  SELECT * | 字段名1,字段名2  FROM 表名 WHERE 字段名 [ NOT ] LIKE ‘匹配字符串’;

(1)百分号(%)通配符

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

  SELECT id,name FROM student2  WHERE name LIKE "S%";  s开头

  SELECT id,name FROM student2 WHERE name NOT LIKE '%y%';不包含y的人

 

(2)下划线(_)通配符

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

  SELECT * FROM student2 WHERE name LIKE 'wu_ong';

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

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

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

 

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

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

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

 

4.2.9   OR 和 AND 一起使用的情况

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

  SELECT * FROM student2 WHERE gender='女' OR gender='男' AND grade=100;

 

 4.3  高级查询

4.3.1  聚合函数

  COUNT( )  返回某列的行数

  SUM( )  返回某列值的和

  AVG( )  返回某列的平均值

  MAX( )  返回某列的最大值

  MIN( )  返回某列的最小值


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

  SELECT COUNT(*) FROM student2;

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

  SELECT SUM(grade) FROM student2;

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

  SELECT AVG(grade) FROM student2;

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

  SELECT MAX(grade) FROM student2;

 

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

  SELECT MIN(grade) FROM student2;

 

4.3.2  对查询结果进行排序

  SELECT * FROM student2 ORDER BY grade DESC;

4.3.3  分组查询

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

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

  SELECT * FROM student2 GROUP BY gender;

 

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

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

  SELECT COUNT(*) ,gender 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;

 

4.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;

 

4.3.5  函数(列表)

MySQL之常用函数

 

 

 

4.4  为表和字段取别名

4.4.1 为表取别名

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

4.4.1 为字段取别名

  SELECT name AS stu_name,gender AS stu_gender FROM student2;

 

 

posted on 2018-08-27 14:47  卜沙卡拉卡  阅读(176)  评论(0编辑  收藏  举报