关闭

SQL数据库语言总结及代码示例

标签: SQLSQL语言全解SQL总结SQL使用SQL大全
21618人阅读 评论(2) 收藏 举报
分类:

转载请注明出处:http://blog.csdn.net/anxpp/article/details/51295020,谢谢!

本文在这上面阅读代码效果更好:http://m.blog.csdn.net/article/details?id=51295020

    很久不用sql,就逐渐忘了,这里作下总结,也方便自己以后查看。

    阅读以下内容,您可能需要了解MySQL中的数据类型:MySQL 数据类型全解

    本文使用Mysql 5.7并使用Mysql workbench演示。

    通宵原创,如果您觉得本文对您有帮助,还请点下赞,谢谢!

概述

    SQL 指结构化查询语言(Structured Query Language),SQL使我们有能力访问数据库SQL是一种 ANSI 的标准计算机语言。

    SQL语言不区分大小写

    可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL)。

    SQL (结构化查询语言)是用于执行查询的语法。但是 SQL 语言也包含用于更新、插入和删除记录的语法。查询和更新指令构成了 SQL 的 DML 部分:

  •     SELECT - 从数据库表中获取数据
  •     UPDATE - 更新数据库表中的数据
  •     DELETE - 从数据库表中删除数据
  •     INSERT INTO - 向数据库表中插入数据

    SQL 的数据定义语言 (DDL) 部分使我们有能力创建或删除表格。我们也可以定义索引(键),规定表之间的链接,以及施加表间的约束。 SQL 中最重要的 DDL 语句:

  •     CREATE DATABASE - 创建新数据库
  •     ALTER DATABASE - 修改数据库
  •     CREATE TABLE - 创建新表
  •     ALTER TABLE - 变更(改变)数据库表
  •     DROP TABLE - 删除表
  •     CREATE INDEX - 创建索引(搜索键)
  •     DROP INDEX - 删除索引

    注意,不同的数据库,SQL上是有一定的差异的,本文以MySQL为例。

1、准备工作

    Mysql的有window的安装版程序,安装时可选Mysql workbench工具,操作很简单,也推荐使用,官网有下载地址,而且是中文的,本文主要介绍SQL(而不是数据库)。下面基于Mysql的正确安装并运行。

    在介绍前,我们需要一些准备工作,包括新建数据库、表等。

    直接执行下面的SQL即可完成数据库,表等的创建以及数据的添加。如果读者是初学,这里不一定要理解下面的语句,后面会逐一介绍。下面的表这么设计,也完全是为了适应各种语句的演示:

  1. /*
  2. 此例介绍SQL语言
  3. */
  4. create database demoDB; /* 创建数据库 */
  5. use demoDB; /* 选择数据库 */
  6. /* 老师 */
  7. create table teachers(
  8. id smallint unsigned AUTO_INCREMENT,
  9. number char(6),
  10. name char(25),
  11. PRIMARY KEY (id),
  12. UNIQUE(number)
  13. );
  14. insert into teachers (number,name) values ('000001','张一'),('000002','李二'),('000003','王三'),('000004','李四'),('000005','李四');
  15. /* 班级 */
  16. create table classes(
  17. id tinyint unsigned AUTO_INCREMENT,
  18. name char(25),
  19. headteacher smallint unsigned,
  20. PRIMARY KEY (id),
  21. FOREIGN KEY (headteacher) REFERENCES teachers(id),
  22. UNIQUE(name)
  23. );
  24. insert into classes (name,headteacher) values ('计算机1班',1),('计算机2班',2),('计算机3班',2);
  25. insert into classes (name) values ('计算机4班');
  26. /* 学生 */
  27. create table students (
  28. id mediumint unsigned AUTO_INCREMENT,
  29. name char(25),
  30. number char(11),
  31. birthday date,
  32. class tinyint unsigned,
  33. duties enum('班长','学委','体委','团支书'),
  34. corporation set('计算机协会','摄影协会','青协'),
  35. PRIMARY KEY (id),
  36. FOREIGN KEY (class) REFERENCES classes(id),
  37. UNIQUE(number)
  38. );
  39. insert into students (name,birthday,class,number) values
  40. ('张小明','19930112',1,11103070101),('黄小明','19930112',1,11103070102),('张啦啦','19940102',1,11103070103),
  41. ('李青','19921130',1,11103070104),('Tom','19930112',2,11103070201),('安妮','19951112',3,11103070301),
  42. ('谢那','19930619',3,11103070302),('奥拉夫','19930802',4,11103070401),('奈德丽','19931223',4,11103070402),
  43. ('德莱文','19920909',4,11103070403);
  44. update students set duties='班长' where number='11103070101';
  45. update students set duties='学委' where number='11103070102';
  46. update students set corporation='计算机协会,青协' where number='11103070101';

    后面的示例代码,这些代码不一定是最好的写法,仅仅是为了演示相关语句,都基于上面创建的数据库和表以及添加的数据。

    接下来就正式开始介绍语句,通常跟在SQL语句后面的表就是这个语句的查询结果。

2、SELECT

    SELECT 语句用于从一张或多张表中选取数据。 结果被存储在一个结果表中(称为结果集)。语法总揽:

  1. SELECT
  2. [ALL | DISTINCT | DISTINCTROW ]
  3. [HIGH_PRIORITY]
  4. [STRAIGHT_JOIN]
  5. [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [SQL_BUFFER_RESULT]
  6. [SQL_CACHE | SQL_NO_CACHE] [SQL_CALC_FOUND_ROWS]
  7. select_expr [, select_expr ...]
  8. [FROM table_references
  9. [PARTITION partition_list]
  10. [WHERE where_condition]
  11. [GROUP BY {col_name | expr | position}
  12. [ASC | DESC], ... [WITH ROLLUP]]
  13. [HAVING where_condition]
  14. [ORDER BY {col_name | expr | position}
  15. [ASC | DESC], ...]
  16. [LIMIT {[offset,] row_count | row_count OFFSET offset}]
  17. [PROCEDURE procedure_name(argument_list)]
  18. [INTO OUTFILE 'file_name'
  19. [CHARACTER SET charset_name]
  20. export_options
  21. | INTO DUMPFILE 'file_name'
  22. | INTO var_name [, var_name]]
  23. [FOR UPDATE | LOCK IN SHARE MODE]]

    以上语法摘自MySQL Workbench语法介绍,下面自浅至深逐一介绍。

    2.1、SELECT和SELECT *

    语法:

  •     SELECT 列名称 FROM 表名称
  •     SELECT * FROM 表名称

    查找所有指定列或全部数据。如果我们要查找所有学生的全部信息或者仅查找学号和姓名:

  1. select * from students;
  2. select number,name from students;

    结果分别为:

   s1      s2

    2.2、DISTINCT

    语法:SELECT DISTINCT 列名称 FROM 表名称

    关键词 DISTINCT 用于返回唯一不同的值。如果同时获取多个字段,仅当多个字段都相同时才会被当做是相同的值。

    我们直接查找老师的名字(select name from teachers;)结果是这样的:

    d1

    如果我们不希望返回值中有重复的值可以这样:

  1. select distinct name from teachers;

    d2

    但是如果改成这样:

  1. select distinct number,name from teachers;

    d3

    因为这时,只有当两个字段的值都相同时,才会被认为是重复的。

    同样的,null值也会去重后返回,此处只是把它当成一个特殊的普通值。

    2.3、WHERE

    语法:SELECT 列名称 FROM 表名称 WHERE 列 运算符 值

    用于选取数据时添加条件。可以使用的运算符如下:

    01

    如果条件为文本值,需要加上单引号,若为数值,不可以加引号。

    查找在1993年及以后出生的学生:

  1. select * from students where birthday >= '19930101';

    w

    AND和OR

    如果有多个条件,使用AND和OR进行连接。如果使用到多个AND和OR,可以添加括号"()"来组合复杂的表达式。

    比如查找1班在1992年或1994年出生的学生:

  1. select * from students where ((birthday >= '19920101' and birthday <= '19921231') or (birthday >= '19940101' and birthday <= '19941231')) and class=1;

    a

    LIKE

    LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。

    语法:SELECT column_name(s) FROM table_name WHERE column_name LIKE pattern

    同样的,可以使用 NOT LIKE 来返回不符合指定模式的结果。

    支持的通配符如下:

    02

    比如要查找姓“李”的学生:

  1. select * from students where name like '李%';

    l

    IN

    IN 操作符允许我们在 WHERE 子句中规定多个值。

    语法:SELECT column_name(s) FROM table_name WHERE column_name IN (value1,value2,...)

    同样的,使用 NOT IN 返回不包含在集合的数据。

    要确定学生中有没有指定名单上的人:

  1. select * from students where name in ('李青','安妮','王老五');

    i

    BETWEEN

    操作符 BETWEEN ... AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期。

    语法:SELECT column_name(s) FROM table_name WHERE column_name BETWEEN value1 AND value2

    不同的数据库对 BETWEEN...AND 操作符的处理方式是有差异的。某些数据库会列出介于 "Adams" 和 "Carter" 之间的人,但不包括 "Adams" 和 "Carter" ;某些数据库会列出介于 "Adams" 和 "Carter" 之间并包括 "Adams" 和 "Carter" 的人;而另一些数据库会列出介于 "Adams" 和 "Carter" 之间的人,包括 "Adams" ,但不包括 "Carter" 。

    使用AND、OR组合可以查找出1993年出生的学生,使用BETWEEN同样可以,而且更简洁:

  1. select * from students where birthday >= '19930101' and birthday <= '19931231';
  2. select * from students where birthday between '19930101' and '19931231';

    它们的结果是一样的:

    b

    2.4、ORDER BY

    ORDER BY 语句用于根据指定的列对结果集进行排序。该语句默认按照升序对记录进行排序。 使用 DESC 关键字可以反序排列记录。

    如果要排序的是多个字段,结果的顺序由靠前的字段优先决定。

    下面分别以生日排序以及生日+班级id反序排序:

  1. select * from students order by birthday;
  2. select * from students order by birthday,class desc;

    结果分别为:

    o1

    o2

    2.5、TOP

    TOP 子句用于规定要返回的记录的数目。

    语法:

  •     SQL Server:SELECT TOP number | percent column_name(s) FROM table_name
  •     MySQL:SELECT column_name(s) FROM table_name LIMIT number
  •     Oracle:SELECT column_name(s) FROM table_name WHERE ROWNUM <= number

    要取年龄最小的3个学生信息,可以这样:

  1. select * from students order by birthday desc limit 3;

   T

    2.6、别名

    通过使用 SQL,可以为列名称和表名称指定别名(Alias)。

    语法:

  •     表: SELECT column_name(s) FROM table_name AS alias_name
  •     列:SELECT column_name AS alias_name FROM table_name

    比如取学生的名字可以这样指定别名:

  1. select name as '名字' from students;

    b

    2.7、JOIN

    join 用于根据两个或多个表中的列之间的关系,从这些表中查询数据。

    有时为了得到完整的结果,我们需要从两个或更多的表中获取结果,我们就需要执行 join。

    数据库中的表可通过键将彼此联系起来。主键(Primary Key)是一个列,在这个列中的每一行的值都是唯一的。在表中,每个主键的值都是唯一的。这样做的目的是在不重复每个表中的所有数据的情况下,把表间的数据交叉捆绑在一起。

    在第一节(准备工作)中,就有这样的例子,如学生表中的班级字段(class)和班级中的班主任字段(headteacher)。

    如果要查找班级以及其对应的班主任,可以这样:

  1. select c.name '班级',t.name '班主任' from classes c,teachers t where c.headteacher = t.id;

    j1

    除了上面的方法,也可以使用关键词 JOIN 来从两个表中获取数据。

    下面是可以使用的 JOIN 类型,以及它们之间的差异:

  •     JOIN: 即 INNER JOIN ,如果表中有至少一个匹配,则返回行
  •     LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行
  •     RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
  •     FULL JOIN: 只要其中一个表中存在匹配,就返回行

    下面通过sql实际运行结果来比较他们的区别。

    join(inner join):

  1. select c.name '班级',t.name '班主任' from classes c join teachers t on c.headteacher = t.id;

    j2

    left join:

  1. select c.name '班级',t.name '班主任' from classes c left join teachers t on c.headteacher = t.id;

    j3

    right join:

  1. select c.name '班级',t.name '班主任' from classes c right join teachers t on c.headteacher = t.id;

    j4

    full join,mysql不直接支持full join,不过我们可以使用union来实现:

  1. select c.name '班级',t.name '班主任' from classes c left join teachers t on c.headteacher = t.id
  2. union
  3. select c.name '班级',t.name '班主任' from classes c right join teachers t on c.headteacher = t.id;

    j5

    如果是更多张表,实现方式也是类似的。

    这样一对比,各种join间的比较就已经很清楚了。

    2.8、UNION

    UNION 操作符用于合并两个或多个 SELECT 语句的结果集。

    请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。

    UNION 结果集中的列名总是等于 UNION 中第一个 SELECT 语句中的列名。

    默认地,UNION 操作符选取不同的值。如果允许重复的值,请使用 UNION ALL。

    语法:

  •     SQL UNION:SELECT column_name(s) FROM table_name1 UNION SELECT column_name(s) FROM table_name2
  •     SQL UNION ALL:SELECT column_name(s) FROM table_name1 UNION ALL SELECT column_name(s) FROM table_name2

    我们要获取所有学生和老师的名字可以这样:

  1. select name, '老师' as '身份' from teachers
  2. union
  3. select name, '学生' from students;

    u

    可以看到,默认返回的是不包含重复项的,如果希望全部显示,请使用“union all”,而且,使用“union all”就不会处理去重(计算)就可以节约资源。

    2.9、SELECT INTO

    SELECT INTO 语句从一个表中选取数据,然后把数据插入另一个表中。SELECT INTO 语句常用于创建表的备份复件或者用于对记录进行存档。

    语法:

  •     把所有的列插入新表: SELECT * INTO new_table_name [IN externaldatabase] FROM old_tablename
  •     只选择部分列插入新表: SELECT column_name(s) INTO new_table_name [IN externaldatabase] FROM old_tablename

    2.10、GROUP BY

    合计函数 (比如 SUM) 常常需要添加 GROUP BY 语句。

    GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组。

    如果直接使用该语句,返回的结果只有每个分组的第一个数据。

    语法:SELECT column_name, aggregate_function(column_name) FROM table_name WHERE column_name operator value GROUP BY column_name

    不适用合计函数直接使用:

  1. select * from students group by class;

    g1

    但更多时候,我们都是结合合计函数(后面函数部分会介绍)使用的,比如统计各班人数:

  1. select class,count(*) from students group by class;

    g2

    2.11、HAVING

    在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与合计函数一起使用。

    语法:SELECT column_name, aggregate_function(column_name) FROM table_name WHERE column_name operator value GROUP BY column_name HAVING aggregate_function(column_name) operator value

    单独使用having时,结果与where是相同的,比如:

  1. select * from students having birthday >= '19940101';
  2. select * from students where birthday >= '19940101';

     h1

    比如要查找人数大于2的班级:

  1. select class,count(*) as stu_num from students group by class having count(*)>2;

    h2

3、INSERT INTO

    INSERT INTO 语句用于向表格中插入新的行。总揽:

  1. INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
  2. [INTO] tbl_name
  3. [PARTITION (partition_name,...)]
  4. [(col_name,...)]
  5. {VALUES | VALUE} ({expr | DEFAULT},...),(...),...
  6. [ ON DUPLICATE KEY UPDATE
  7. col_name=expr
  8. [, col_name=expr] ... ]
  9. Or:
  10. INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
  11. [INTO] tbl_name
  12. [PARTITION (partition_name,...)]
  13. SET col_name={expr | DEFAULT}, ...
  14. [ ON DUPLICATE KEY UPDATE
  15. col_name=expr
  16. [, col_name=expr] ... ]
  17. Or:
  18. INSERT [LOW_PRIORITY | HIGH_PRIORITY] [IGNORE]
  19. [INTO] tbl_name
  20. [PARTITION (partition_name,...)]
  21. [(col_name,...)]
  22. SELECT ...
  23. [ ON DUPLICATE KEY UPDATE
  24. col_name=expr
  25. [, col_name=expr] ... ]

    语法:

  •     INSERT INTO 表名称 VALUES (值1, 值2,....)
  •     也可以指定所要插入数据的列: INSERT INTO table_name (列1, 列2,...) VALUES (值1, 值2,....)

    如果插入的数据跟建表时的类型有冲突,就会涉及到冲突的处理,而处理的方式,通常也跟数据库运行的模式(如严格模式和非严格模式)有关,至于具体如何处理,可以参考:MySQL 中的数据类型介绍

    在第一节(准备工作)中,我们就多次运用到了该语句。

4、UPDATE

    Update 语句用于修改表中的数据。总揽:

  1. Single-table syntax:
  2. UPDATE [LOW_PRIORITY] [IGNORE] table_reference
  3. SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ...
  4. [WHERE where_condition]
  5. [ORDER BY ...]
  6. [LIMIT row_count]
  7. Multiple-table syntax:
  8. UPDATE [LOW_PRIORITY] [IGNORE] table_references
  9. SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ...
  10. [WHERE where_condition]

    语法: UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值。

    在第一节(准备工作)中,我们就多次运用到了该语句。

5、DELETE

    DELETE 语句用于删除表中的行。总揽:

  1. Single-Table Syntax
  2. DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl_name
  3. [PARTITION (partition_name,...)]
  4. [WHERE where_condition]
  5. [ORDER BY ...]
  6. [LIMIT row_count]
  7. Multiple-Table Syntax
  8. DELETE [LOW_PRIORITY] [QUICK] [IGNORE]
  9. tbl_name[.*] [, tbl_name[.*]] ...
  10. FROM table_references
  11. [WHERE where_condition]
  12. Or:
  13. DELETE [LOW_PRIORITY] [QUICK] [IGNORE]
  14. FROM tbl_name[.*] [, tbl_name[.*]] ...
  15. USING table_references
  16. [WHERE where_condition]

    语法:DELETE FROM 表名称 WHERE 列名称 = 值

    比如,如果某个学生退学了,我们需要将其信息转到另外一张表存放,而当前所在的表需要删除本条数据,我们就可以这样做:

  1. delete from students where number='要删除的学生的学号';

6、CREATE

    CREATE可以创建数据库、表、索引或是视图等,此处介绍语句,所以将他们放到同一个大的标题下面。

    6.1、CREATE DATABASE

    CREATE DATABASE 用于创建数据库。

    语法:CREATE DATABASE database_name

    在第一节(准备工作)中,我们就使用过该语句,很简单。

    如果在初始化时,希望只建不存在的表,如果已经存在,就忽略,可以这样做:

  1. create database if not exists demoDB;

    这样的话,执行该语句,如果数据库异常存在,就不会报错,而只是一个警告了。

    6.2、CREATE TABLE

    CREATE TABLE 语句用于创建数据库中的表。总揽:

  1. Syntax:
  2. CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
  3. (create_definition,...)
  4. [table_options]
  5. [partition_options]
  6. Or:
  7. CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
  8. [(create_definition,...)]
  9. [table_options]
  10. [partition_options]
  11. select_statement
  12. Or:
  13. CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
  14. { LIKE old_tbl_name | (LIKE old_tbl_name) }
  15. create_definition:
  16. col_name column_definition
  17. | [CONSTRAINT [symbol]] PRIMARY KEY [index_type] (index_col_name,...)
  18. [index_option] ...
  19. | {INDEX|KEY} [index_name] [index_type] (index_col_name,...)
  20. [index_option] ...
  21. | [CONSTRAINT [symbol]] UNIQUE [INDEX|KEY]
  22. [index_name] [index_type] (index_col_name,...)
  23. [index_option] ...
  24. | {FULLTEXT|SPATIAL} [INDEX|KEY] [index_name] (index_col_name,...)
  25. [index_option] ...
  26. | [CONSTRAINT [symbol]] FOREIGN KEY
  27. [index_name] (index_col_name,...) reference_definition
  28. | CHECK (expr)
  29. column_definition:
  30. data_type [NOT NULL | NULL] [DEFAULT default_value]
  31. [AUTO_INCREMENT] [UNIQUE [KEY] | [PRIMARY] KEY]
  32. [COMMENT 'string']
  33. [COLUMN_FORMAT {FIXED|DYNAMIC|DEFAULT}]
  34. [STORAGE {DISK|MEMORY|DEFAULT}]
  35. [reference_definition]
  36. data_type:
  37. BIT[(length)]
  38. |