SQL 学习记录

前段时间看了,发现效果不大,这次还是写成正式的笔记好了!下面写的例子都是在 MySQL 验证过。Oracle部分例子没有

[TOC]

SQL DML 和 DDL

1、SQL 的 DML 部分:于更新、插入和删除记录的语法。

  • SELECT - 从数据库表中获取数据

  • UPDATE - 更新数据库表中的数据

  • DELETE - 从数据库表中删除数据

  • INSERT INTO - 向数据库表中插入数据

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

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

select 列名 from 表名

select * from 表名

SELECT DISTINCT : SELECT DISTINCT 列名 FROM 表名

排除重复数据

SELECT DISTINCT 列名 from 表名
WHERE 语句: ... WHERE ...

在 WHERE 语句后面常用的操作符

=
<> 不等于
>
<
>=
<=
BETWEEN 在某个值范围内
LIKE 模糊匹配搜索
AND 两个条件都成立 ... WHERE FirstName='Thomas' AND LastName='Carter'
OR 其中一个条件成立 ... WHERE FirstName='Thomas' OR LastName='Carter'

注解: 有的 SQL 版本不等于 <> 可以写成 !=

ORDER BY : ... WHERE ORDER BY DESC

对结果集进行排序

  • 这必须是查询好后能返回一个结果,所以 ORDER BY 一般是放在查询语句最后。
  • 默认是ASC/升序 , DESC /降序
SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC
INSERT INTO : INSERT INTO 表名 VALUES ( VALUE1, VALUE2...)
-- 默认全部插入
INSERT INTO 表名称 VALUES (值1, 值2,....)  -- 注意插入值的顺序和创建表列的顺序一致

-- 指定行列插入
INSERT INTO Persons (LastName, Address) VALUES ('Wilson', 'Champs-Elysees')
UPDATE : UPDATE 表名 SET 列名 = 新值 WHERE ...
UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值
DELETE : DELETE FROM 表名 WHERE ...
DELETE FROM 表名称 WHERE 列名称 = 值

-- 删除所有的行
DELETE FROM table_name
DELETE * FROM table_name


TOP 子句:限制返回条数,实现分页功能
  • MySQL 语法

    -- 列是从 0 开始计算的
    SELECT *
    FROM Persons
    LIMIT 0,5;
    
    -- 从第一列开始共返回5列数据
    SELECT *
    FROM Persons
    LIMIT 5;
    
    -- SQL 中的 LIMIT 语句前面是不需要加 WHERE 语句的。
    
  • Oracle

    SELECT column_name(s)
    FROM table_name
    WHERE ROWNUM <= number
    
    SELECT *
    FROM Persons
    WHERE ROWNUM <= 5
    
    -- ROWNUM 是没有 >= 的因此在做分页查询的时候会用 2 层 SELECT 查询语句
    
SQL LIKE : ... WHERE 列名 LIKE ''

实现模糊查询功能

SELECT column_name(s)
FROM table_name
WHERE column_name LIKE pattern

-- % 通配符的使用

-- % 可以理解为占位符 0 个或多个位置,以 "宝" 结尾的列都能查询出来
SELECT * FROM websites  WHERE NAME LIKE '%宝';

-- 包含
SELECT * FROM websites  WHERE NAME LIKE '%宝%';

-- 不包含
SELECT * FROM websites  WHERE NAME NOT LIKE '%宝%';

-- _ 只能代替一个字符的位置所以可以搜索出 2 个长度并且是以“宝”结尾的列
SELECT * FROM websites  WHERE NAME LIKE '_宝';

-- 
SQL 通配符
字符 说明 例子 MySQL
% 代替一个或多个字符 yes
_ 仅代替一个字符 yes
[charlist] 字符中任何一个单一的字符 ... WHERE country LIKE '[C]%'; no
[^charlist] or [! charlist] 不在字符列中任何一个单一的字符 ... WHERE country LIKE '[!N]%'; no

表格中标注 no 的是我在MySQL里没有验证出结果

SQL IN : ... WHERE 列名 IN (value1,value2,...)
SELECT column_name(s)
FROM table_name
WHERE column_name IN (value1,value2,...)
SQL BETWEEN : WHERE 列名 BETWEEN value1 AND value2
SELECT column_name(s)
FROM table_name
WHERE column_name
BETWEEN value1 AND value2
SQL Alias(AS): 别名
SELECT LastName AS Family, FirstName AS Name
FROM Persons

-- 其实也是可以不用写 AS 直接用空格代替

SELECT LastName  Family, FirstName  Name
FROM Persons

注意事项

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

推荐阅读更多精彩内容