SQL必知必会笔记(1-6)

生成数据库表和数据的SQL文件

第1课:了解SQL

1、数据库基础

  • 数据库(database):保存有组织的数据的容器

数据库软件也称为数据库管理系统(DBMS);

  • 表(table):某种特定类型数据的结构化清单

  • 列:表中的一个字段。所有表都是由一个或多个列组成

  • 数据类型:限定可存储在列中的数据的种类

  • 行:表中的一条记录

  • 主键:一列(或一组列),其值能够唯一标识表中每一行

应该总是定义主键,主键满足的条件:

  • 任意两行都不具有相同的主键值
  • 每一行都必须具有一个主键(主键不允许为NULL)
  • 主键列中的值不允许修改或更新
  • 主键值不能重用(如果某行被删除,它的主键不能赋给以后的新行)


1.2、什么是SQL

  • SQL:Structured Query Language(结构化查询语言)

SQL的优点:

  • 几乎所有重要的DBMS都支持SQL;
  • SQL简单易学;
  • SQL可以进行非常复杂和高级的数据库操作;


第2课:检索数据



SELECT语句

SELECT语句用于从一个或多个表中检索信息

关键字不能用作表或列的名字;


检索单个列:

SELECT prod_name FROM products;

从products表中检索名为prod_name的列,FROM关键字指出从那个表中检索数据。

多条SQL语句必须以分号(即";")分割

SQL语句不区分大小写,一般情况下,为了易于阅读和维护,对关键字使用大写,而对列名和表名使用小写;


检索多个列

SELECT prod_id, prod_name, prod_price FROM products;

多个列之间使用逗号分隔


检索所有列

SELECT * FROM products;

一般而言除非确实需要表中的每一列,否则最好不要使用通配符,使用通配符通常会降低检索和应用程序的性能;


检索不同的值

SELECT DISTINCT vend_id FROM products;
  • DISTINCT关键字指示数据库返回不同的值;
  • DISTINCT关键字作用于所有的列,不仅仅是紧跟其后的那一列;


限制结果

如果查询的数据有很多,只想返回一定的行数,则可以根据不同的DBMS的关键字来实现

  • SQL Server和Access: SELECT TOP 5 prod_name FROM products;
  • DB2: SELECT prod_name FROM products FETCH FIRST 5 ROWS ONLY;
  • Oracle: SELECT prod_name FROM products WHERE ROWNUM <= 5;
  • MySQL / MariaDB / PostgreSQL / SQLite: SELEC prod_name FROM products LIMIT 5;

为了得到后面的5行,可以使用OFFSET关键字: SELECT prod_name FROM products LIMIT 5 OFFSET 5;

指示DBMS从OFFSET指定的第5行起行起,查询LIMIT后的 5 行数据;


SQL注释

使用注释的原因:

  • 随着SQL语句的变长,复杂性增加,需要添加一些描述性的文字,以便于以后自己和其他人参考;
  • 在文件开头添加一些个人的联系方式、程序描述以及一些说明;
  • 暂时停止不需要执行的SQL代码;
  • 双连字符注释

    SELECT prod_name    -- 这是一条注释

    FROM products;

两个连字符之后的便是注释的内容

  • 另一种注释:

      # 这是一条注释
      # 这是一条注释
    
  • 多行注释

      /*
       SELECT prod_name, vend_id
       FROM products
       LIMIT 5 OFFSET 10;
      */
    


第3课:排序检索数据


排序顺序

子句:SQL由子句构成,一个子句通常由一个关键字加上所提供的数据组成。


ORDER BY 子句可以对检索出的数据进行排序

SELECT prod_name
FROM products
ORDER BY prod_name;

ORDER BY 子句的位置总是在SELECT语句的最后一条,否则会报错。


按多个列排序

SELECT prod_id, prod_price, prod_name 
FROM products 
ORDER BY prod_price, prod_name;


按排列的位置排序

SELECT prod_id, prod_price, prod_name
FROM products
ORDER BY 2, 3;


指定排序方向

SELECT prod_id, prod_price, prod_name
FROM products
ORDER BY prod_price DESC, prod_name;

DESC是降序排列(DESCENDING),默认是升序排列ASC(ASCENDING);

DESC关键字只能应用到直接位于其前的列名,如果想对多个列进行降序排列,必须对每一列指定DESC关键字;


第4课:过滤数据


只检索所需数据需要指定搜索条件(search criteria),搜索条件也称为过滤条件(filter condition);

使用WHERE子句

SELECT prod_name, prod_price
FROM products
WHERE prod_price = 3.49;


WHERE子句操作符

操作符 说 明
= 等于
<> 不等于
!= 不等于
< 小于
<= 小于等于
!< 不小于
> 大于
>= 大于等于
!> 不大于
BETWEEN 在指定的两个值之间
IS NULL 为NULL值

并非所有的DBMS都支持以上所有的操作符,如<>就不是所有的DBMS支持;

实例

查询单个值

查询小于价格小于10的商品

SELECT prod_name, prod_price
FROM products
WHERE prod_price < 10
ORDER BY prod_price DESC, prod_name;

限定查询

SELECT vend_id, prod_name
FROM products
WHERE vend_id != 'DLL01';

范围查询

SELECT prod_name, prod_price
FROM products
WHERE prod_price BETWEEN 3 AND 10;

两个值之间需要 AND 关键字隔开

NULL值查询

SELECT cust_name
FROM customer
WHERE cust_email IS NULL;


第5课:高级数据过滤

5.1、组合WHERE子句

SQL允许给出多个WHERE子句,这些子句以 AND 子句或 OR 子句的方式组合:

  • AND操作符:AND指示DBMS检索只满足所有给定所有条件的行。

      SELECT prod_id, prod_price, prod_name
      FROM products
      WHERE vend_id = 'DLL01' AND prod_price <= 4
      ORDER BY prod_name DESC;
    


  • OR操作符:用来表示检索匹配任一给定条件的行。

      SELECT prod_name, prod_price
      FROM products
      WHERE vend_id = 'DLL01' OR vend_id = 'BRS01'
      ORDER BY prod_price DESC;
    


求值顺序

AND 操作符的优先级高于 OR ,所以在同时使用时建议加上圆括号加以区别;

实例一:

SELECT prod_name, prod_price
FROM products
WHERE vend_id = 'DLL01' OR vend_id = 'BRS01' AND prod_price >= 10
ORDER BY prod_price DESC;

实例二:

SELECT prod_name, prod_price
FROM products
WHERE (vend_id = 'DLL01' OR vend_id = 'BRS01') AND prod_price >= 10 
ORDER BY prod_price DESC;


IN 操作符

IN操作符用来指定的范围,范围中的每个条件都可以匹配。

SELECT prod_id, prod_name, prod_price
FROM products
WHERE vend_id IN ('DLL01', 'BRS01')
ORDER BY prod_id;

使用 IN 操作符的优点:

  • 在有很多合法选项时,IN操作符的语法更清楚,更直观;
  • 在与AND和OR等其他操作符组合使用时,求值顺序更容易管理;
  • IN 操作符一般比一组OR操作符执行的更快;
  • IN 操作符的最大优点是可以包含SELECT语句,能够更动态的建立WHERE子句;


NOT操作符

NOT操作符用来否定其后跟的条件;

实例:

SELECT prod_id, prod_name
FROM products
WHERE NOT vend_id = 'DLL01'
ORDER BY prod_id;C

以上实例等同于:

SELECT prod_id, prod_name
FROM products
WHERE vend_id != 'DLL01'
ORDER BY prod_id;


第6课:用通配符进行过滤

LIKE操作符

通配符(wildcard):用来匹配值的一部分的特殊字符


为在搜索子句中使用通配符,必须使用LIKE操作符。LIKE指示DBMS,后跟的搜索模式利用通配符而不是简单的相等匹配进行比较。


通配符只能用于文本字段(字符串)

百分号(%)通配符

% 表示任何字符出现任意次数;

实例: 找出所有以Fish起头的产品

SELECT prod_id, prod_name
FROM products
WHERE prod_name LIKE 'Fish%';

搜索时会区分大小写;


使用多个%通配符:找出所有包含“bean bag”的产品

SELECT prod_id, prod_name
FROM products
WHERE prod_name LIKE '%bean bag%';

在搜索模式的中间:找出以F开头,以y结尾的所有产品

SELECT prod_id, prod_name
FROM products
WHERE prod_name LIKE 'F%y';

在中间使用时搜索电子邮件很有用,如:WHERE email LIKE 'b%@163.com';

%不会匹配NULL


下划线(_)匹配符

下划线通配符是用来匹配单个字符的

实例:匹配两个

SELECT prod_id, prod_name
FROM products
WHERE prod_name LIKE '__ inch teddy bear';

匹配任意个:

SELECT prod_id, prod_name
FROM products
WHERE prod_name LIKE '% inch teddy bear';

方括号([])通配符

方括号([])匹配符用来指定一个字符集,它必须匹配指定位置(通配符的位置)的一个字符;

并不是所有的DBMS都支持创建集合的[],只有微软的Access和SQL Server支持。

SELECT cust_contact
FROM customers
WHERE cust_contact LIKE '[JM]%'
ORDER BY cust_contact;

对[]进行否定,[^JM]%


使用通配符的技巧:

  • 不要过度使用通配符,如果能达到相同目的,应该使用其他操作符;
  • 在确实需要使用时,尽量不要把它们用在搜索模式的开始处,因为那样是搜索起来最慢的;
  • 仔细注意通配符的位置;

....

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,718评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,683评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,207评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,755评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,862评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,050评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,136评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,882评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,330评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,651评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,789评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,477评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,135评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,864评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,099评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,598评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,697评论 2 351

推荐阅读更多精彩内容