1.插入记录

  INSERT INTO tablename

  (fields1, fields2, ..., fieldsn)

  VALUES

  (value1, value2, ..., valuen)

  例: 

    INSERT INTO emp

    (emp, hiredate, sal, deptno)

    VALUES

    ('zzxl', '2000-01-01', '2000', 1)

    可以不指定字段名称,但是 values 后面的顺序还应该和字段的排列顺序一致

  一次性插入多条记录

    INSERT INTO tablename

    (fields1, fields2, ..., fieldsn)

    VALUES

    (value11, value12, ..., value1n),

    (value21, value22, ..., value2n),

     ...

    (valuen1, valuen2, ..., valuenn)

  例:

    INSERT INTO emp

    (emp, hiredate, sal, deptno)

    VALUES

    ('zs', '2003-01-01', '2000', 2),

    ('ls', '2005-01-01', '2000', 3)

2.更新记录

  UPDATE tablename

  SET   field1=value1,field2=value2,...,fieldn=valuen

  [WHERE CONDITION]

  例:

    UPDATE emp

    SET   ename='wem'

    WHERE  ename='zzxl'

  同时更新多个表中数据

  UPDATE t1,t2,...,tn

  SET   t1.field1=expr1,...,tn.field2=exprn

  [WHERE CONDITION]

  例:

    UPDATE emp a, dept b

    SET   a.sal=a.sal*b.deptno,b.deptname=a.ename

    WHERE  a.deptno=b.deptno

3.删除记录

  DELETE FROM tablename

  [WHERE CONDITION]

  例:

    DELECT FROM emp

    WHERE  ename='dony'

  一次删除多个表的数据

  DELETE t1,t2,...,tn

  FROM    t1,t2,...,tn

  [WHERE  CONDITION]

  如果 FROM 后面的表名用别名,则 DELETE 后面也要用相应的别名,否则会提示语法错误。

  例:

    DELETE a, b

    FROM    emp a, dept b

    WHERE  a.deptno=b.deptno

    AND  a.deptno=3

4.查询记录

  SELECT *

  FROM    tablename

  [WHERE CONDITION]  

  例:

    SELECT *

    FROM    emp

  查询不重复的记录

  SELECT DINTINCT field1,field2,...,field3

  FROM    tablename

  [WHERE CONDITION]

  例:

    SELECT DISTINCT deptno

    FROM  emp

  条件查询

  WHERE 条件后面可以使用=, >, <, >=, <=, != 等比较运算符;多个条件之间还可以使用 OR, AND等逻辑运算符进行多条件联合查询

  排序和限制

  SELECT *

  FROM  tablename

  [WHERE CONDITION]

  [ORDER  BY field1 [DESC|ASC],

         field2 [DESC|ASC],

         ...

         fieldn [DESC|ASC]]

  DESC表示按照字段进行降序排列,ASC表示升序排列[默认排序].

  例:

    SELECT *

    FROM    emp

    ORDER BY sal

  部分显示

  SELECT ...

  [LIMIT offset_start, row_count]

  offset_start表示起始偏移量,row_count表示行数。

  默认情况下起始偏移量为0,只要写记录数就可以。

  limit经常和order by一起配合使用来进行记录的分页显示。

  聚合

  很多情况下,用户需要进行一些汇总操作,比如统计整个公司的人数或者统计每个部门的人数。这时就要用到SQL的聚合操作。

  SELECT [field1, field2, ..., fieldn] FUN_NAME

  FROM  table_name

  [WHERE CONDITION]

  [GROUP  BY field1, field2, ..., fieldn

   WITH    ROLLUP]]

  [HAVING where_condition]

  FUN_NAME表示要做的聚合操作,也就是聚合函数,常用的有sum, count, max, min等。

  GROUP BY表示要进行分类聚合的字段,比如要按照部门分类统计员工数量,部门就应该写在GROUP BY 后面。

  WITH ROLLUP 是可选语法,表明是否对分类聚合后的结果进行再汇总。

  HAVING关键字表示对分类后的结果再进行条件过滤。

  HAVING 和 WHERE 的区别在于,HAVING 是对聚合后的结果进行条件的过滤,而 WHERE 是在聚合前就对结果进行过滤,如果逻辑允许,我们尽可能先用

  WHERE进行过滤,这样因为结果集减小,将对聚合的效率大大提高,最后在根据逻辑看是否用 HAVING 进行再过滤。

  例:(统计各部门人数)

    SELECGT deptno, count(*) total

    FROM      emp

    GROUP BY deptno

  例:(统计各部门人数,及总人数)

    SELECT deptno, count(*) total

    FROM    emp

    GROUP BY deptno

    WITH ROLLUP

  例:(统计人数大于1的部门)

    SELECT deptno, count(*) total

    FROM    emp

    GROUP BY deptno

    HAVING total>1

  例:(统计公司所有员工的薪水总额,最高和最低薪水)

    SELECT SUM(sal), MAX(sal), min(sal)

    FROM    emp

  表连接

  当需要同时显示多个表中的字段时,就可以用表连接来实现这样的功能。

  从大类上分,表连接分为内连接和外连接,他们之间最主要的区别是,内连接仅选出两张表中互相匹配的记录,

  而外连接会选出其他不匹配的记录。我们常用的是内连接。

  例:

    SELECT ename, deptname

    FROM  emp, dept

    WHERE emp.deptno=dept.deptno

  外连接又分为左连接和右连接。

  左连接:包含所有的左边表中的记录甚至是右边表中没有和他匹配的记录。

  右连接:包含所有的右边表中的记录甚至是左边表中没有和他匹配的记录。

  SELECT ...

  FROM    ...

  [LEFT|RIGHT] JOIN ... ON

  ...

  例:

    SELECT ename, deptname

    FROM  emp

    LEFT JOIN dept ON

    emp.deptno=dept.deptno

    SELECT ename, deptname

    FROM  dept

    RIGHT JOIN emp ON

    emp.deptno=dept.deptno

  子查询

  某些情况下,当进行查询的时候,需要的条件是另外一个 SELECT 语句的结果,这个时候,就要用到子查询。

  用于子查询的关键字主要包括 IN, NOT IN, =, !=, EXISTS, NOT EXISTS

  例:

    SELECT *

    FROM  emp

    WHERE deptno

      IN (

      SELECT deptno

      FROM    dept)

    如果子查询记录数唯一,还可以用 = 代替 IN

    对于不唯一的查询记录可使用limit控制查询记录为唯一。(有需求的话)

    某些情况下,子查询可以转化为表连接。

    表连接在很多情况下用于优化子查询。

  记录联合

  我们经常碰到这样的应用,将两个表的数据按照一定的查询条件查询出来以后,将结果合并到一起显示出来。

  这个时候就需要用到 UNION 和 UNION ALL 来实现这样的功能.

  SELECT *

  FROM  t1

  UNION|UNION ALL

  SELECT *

  FROM    t2

  ...

  UNION|UNION ALL

  SELECT *

  FROM    tn

  例:

    SELECT deptno

    FROM  emp

    UNION   ALL

    SELECT deptno

    FROM  dept

    

    SELECT deptno

    FROM  emp

    UNION

    SELECT deptno

    FROM  dept

    UNION 和 UNION ALL 的主要区别是 UNION ALL是把结果集直接合并在一起,而 UNION 是将 UNION ALL 后的结果进行一次 DISTINCT,去除重复记录后的结果。

    使用的时候需要保持列数相同。

MySQL--基础SQL--DML的更多相关文章

  1. mysql 基础sql语法总结 (二)DML

    二.DML(增.删.改) 1)插入数据 第一种写法:INSERT INTO 表名 (列名1,列名2,,......)VALUES(列值1,列值2,......) 第二种写法:INSERT INTO 表 ...

  2. mysql基础sql进阶

    回顾前面的基础命令语句 修改数据表 添加字段: alter table 表名 add 字段名 列类型[not null|null][primary key][unique][auto_incremen ...

  3. mysql 基础sql语法总结(一)DDL

    mysql数据库: SQL数据库语言可分为四部分: 1.DDL:对数据库或表的进行操作结构操作 2.DML:对表的记录进行更新(增.删.改)* 3.DQL:对表的内容进行查询 **(重难点) 4.DC ...

  4. MySQL基础之DML语句

    DML 语句 DML(Data Manipulation Language)语句:数据操纵语句. 用途:用于添加.修改.删除和查询数据库记录,并检查数据完整性. 常用关键字:insert.update ...

  5. mysql 基础sql语句

    1.mysqladmin语句:  # 查看mysql版本 mysqladmin version  # 更改root用户密码 mysqladmin -u root -p原密码 password '新密码 ...

  6. mysql基础SQL练习

    许久收藏的练习mysql语句的,现在看来任然有学习价值! 表如下: Student(Sid,Sname,Sage,Ssex) 学生表 Course(Cid,Cname,Tid) 课程表 SC(Sid, ...

  7. MySQL基础SQL命令---增删改查

    1.表操作: create table tableName (id int(6) not null primary key auto_increatment,name varchar(10) not ...

  8. MySQL 基础 SQL 操作

    MySQL 用户 --登录 mysql -u<用户名> -p[密码] --修改密码 mysqladmin -u<用户名> -p[密码] password <new_pas ...

  9. MySQL基础整理(一)之SQL基础(未完成)

    大家好,我是浅墨竹染,以下是MySQL基础整理(一)之SQL基础 1.SQL简介 SQL(Structure Query Language)是一种结构化查询语言,是使用关系模型的数据库应用语言. 2. ...

  10. mysql使用基础 sql语句(一)

    csdn博文地址:mysql使用基础 sql语句(一)  点击进入 命令行输入mysql -u root -p,回车再输入密码,进入mysql. 终端命令以分号作为一条语句的结束,可分为多行输入,只需 ...

随机推荐

  1. JuJu团队11月25号工作汇报

    JuJu团队11月25号工作汇报 JuJu   Scrum 团队成员 今日工作 剩余任务 困难 于达 实现随机采样函数,进行onehot处理 预处理数据集,将数据集转为矩阵读入 数据集预处理比想象中麻 ...

  2. Redis 详解 (一) redis的简介和安装

    目录 1.Redis 的简介 2.Redis 下载 3.安装环境 4.编译安装 5.启动Redis 6.关闭Redis 7.注意事项 工作中一直在用 Redis,但是一直没有进行系统的总结,这个系列的 ...

  3. 数论 CF27E Number With The Given Amount Of Divisors

    求因子数一定的最小数(反素数) #include<iostream> #include<string> #include<cmath> #include<cs ...

  4. vim使用技巧(常用指令)

    1. vim基础操作 vim是从 vi 发展出来的一个文本编辑器 .代码补完.编译及错误跳转等做了一些增强 1.1 进入编辑模式 命令 含义 i和I i在光标前插入,I在行首插入. a和A a在光标后 ...

  5. POJ 2251 Dungeon Master(三维空间bfs)

    题意:三维空间求最短路,可前后左右上下移动. 分析:开三维数组即可. #include<cstdio> #include<cstring> #include<queue& ...

  6. 由于找不到msvcp100.dll无法继续执行代码

    最近重装系统之后安装mysql, 执行 mysqld install 命令时出现 : 由于找不到msvcp100.dll无法继续执行代码... 解决办法 下载 Microsoft Visual C++ ...

  7. 数据库连接池C3P0的使用

    一.直接使用代码链接(一般企业开发不会用到.大多数用方法二) 1.导入jar 2.新建JDBCUtil import java.io.FileInputStream; import java.io.I ...

  8. tf.summary可视化参数

    1.tf.summary.scalar('accuracy', accuracy) 损失值.准确率随着迭代次数的进行,其指标变化情况:一般在画loss,accuary时会用到这个函数. 2.tenso ...

  9. 吴裕雄--天生自然TensorFlow2教程:测试(张量)- 实战

    import tensorflow as tf from tensorflow import keras from tensorflow.keras import datasets import os ...

  10. c# 数据库操作,多数据库操作、数据库操作异常报错等问题

    1.引入相关的命名空间 在C#中要操作数据库,一般情况需要引入两个命名空间,在三种连接模式中都要引入下面的命名空间: System.Data;描述与数据源连接的当前状态. // // 摘要: // 连 ...