SQL语句速查指南2

★查询数据表中的部分数据------TOP子句(从某行到某行):

1.SQL Server 的语法:

SELECT TOP number|percent column_name(s)

FROM table_name

eg:

SELECT TOP 2 * FROM Persons (从"Persons" 表中选取头两条记录)

SELECT TOP 50 PERCENT * FROM Persons(从"Persons" 表中选取 50% 的记录。)


2.MySQL 语法:

SELECT column_name(s)

FROM table_name

LIMIT number

eg:

SELECT *

FROM Persons

LIMIT 5


3.Oracle 语法:

SELECT column_name(s)

FROM table_name

WHERE ROWNUM <= number

eg:

SELECT *

FROM Persons

WHERE ROWNUM <= 5

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

SELECT column_name(s)

FROM table_name

WHERE column_name LIKE pattern

eg:

SELECT * FROM Persons

WHERE City LIKE 'N%' (从"Persons" 表中选取居住在以 "N" 开始的城市里的人)

eg:

SELECT * FROM Persons

WHERE City LIKE '%g'(从 "Persons" 表中选取居住在以 "g" 结尾的城市里的人)

eg:

SELECT * FROM Persons

WHERE City LIKE '%lon%'(从 "Persons" 表中选取居住在包含 "lon" 的城市里的人)

eg:

SELECT * FROM Persons

WHERE City NOT LIKE '%lon%'(使用 NOT 关键字,从 "Persons" 表中选取居住在不包含 "lon" 的城市里的人:)

(注:"%" 可用于定义通配符(模式中缺少的字母))

★SQL 通配符-------SQL 通配符可以替代一个或多个字符,必须与 LIKE 运算符一起使用

1.通配符“%”----替代一个或多个字符

eg:

SELECT * FROM Persons

WHERE City LIKE 'Ne%'(从"Persons" 表中选取居住在以 "Ne" 开始的城市里的人)

eg:

SELECT * FROM Persons

WHERE City LIKE '%lond%'(从 "Persons" 表中选取居住在包含 "lond" 的城市里的人)


2.通配符“_”----仅替代一个字符

eg:

SELECT * FROM Persons

WHERE FirstName LIKE '_eorge'(从 "Persons" 表中选取名字的第一个字符之后是 "eorge" 的人)

eg:

SELECT * FROM Persons

WHERE LastName LIKE 'C_r_er'(从"Persons" 表中选取姓氏以 "C" 开头,然后是一个任意字符,然后是 "r",然后是任意字符,然后是 "er"的人)


3.通配符“[charlist]”-----字符列中的任何单一字符

eg:

SELECT * FROM Persons

WHERE City LIKE '[ALN]%'(从 "Persons" 表中选取居住的城市以 "A" 或 "L" 或 "N" 开头的人)


4通配符“[^charlist]”或“[!charlist]”-----不在字符列中的任何单一字符

eg:SELECT * FROM Persons

WHERE City LIKE '[!ALN]%'(从"Persons" 表中选取居住的城市不以 "A" 或 "L" 或 "N" 开头的人)

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

SELECT column_name(s)

FROM table_name

WHERE column_name IN (value1,value2,...)

eg:

SELECT * FROM Persons

WHERE LastName IN ('Adams','Carter') (从“Persons”表中选取姓氏为 Adams 和 Carter 的人)

★BETWEEN 操作符-------在 WHERE 子句中使用,作用是选取介于两个值之间的数据范围

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

SELECT column_name(s)

FROM table_name

WHERE column_name

BETWEEN value1 AND value2

eg:

SELECT * FROM Persons

WHERE LastName

BETWEEN 'Adams' AND 'Carter'(以字母顺序选取介于 "Adams"和 "Carter"之间的人)

(注:不同的数据库对 BETWEEN...AND 操作符的处理方式是有差异的。某些数据库会列出介于 "Adams" 和 "Carter" 之间的人,但不包括 "Adams" 和 "Carter" ;某些数据库会列出介于 "Adams" 和 "Carter" 之间并包括 "Adams" 和 "Carter" 的人;而另一些数据库会列出介于 "Adams" 和 "Carter" 之间的人,包括 "Adams" ,但不包括 "Carter" 。所以,请检查你的数据库是如何处理 BETWEEN....AND 操作符的!)

eg:

SELECT * FROM Persons

WHERE LastName

NOT BETWEEN 'Adams' AND 'Carter'(如需使用上面的例子显示范围之外的人,请使用 NOT 操作符)


★SQL Alias(别名)-------为列名称和表名称指定别名(Alias),别名使查询程序更易阅读和书写。

表的别名:

SELECT column_name(s)

FROM table_name

AS alias_name

eg:

SELECT po.OrderID, p.LastName, p.FirstName

FROM Persons AS p, Product_Orders AS po

WHERE p.LastName='Adams' AND p.FirstName='John'(有两个表分别是:"Persons" 和 "Product_Orders"。我们分别为它们指定别名 "p" 和 "po"。我们希望列出 "John Adams" 的所有定单。)

列的别名:

SELECT column_name AS alias_name

FROM table_name

eg:

SELECT LastName AS Family, FirstName AS Name

FROM Persons

★SQL JOIN-------用于根据两个或多个表中的列之间的关系,从这些表中查询数据

Join 和 Key:

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

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

两个表间的引用:

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

FROM Persons, Orders

WHERE Persons.Id_P = Orders.Id_P

等价于

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

FROM Persons

INNER JOIN Orders

ON Persons.Id_P = Orders.Id_P

ORDER BY Persons.LastName(我们希望列出所有人的定购)

(注:INNER JOIN 与 JOIN 是相同的)

★INNER JOIN 关键字-------在表中存在至少一个匹配时,INNER JOIN 关键字返回行

SELECT column_name(s)

FROM table_name1

INNER JOIN table_name2

ON table_name1.column_name=table_name2.column_name

eg:

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

FROM Persons

INNER JOIN Orders

ON Persons.Id_P=Orders.Id_P

ORDER BY Persons.LastName(希望列出所有人的定购)

(注:INNER JOIN 关键字在表中存在至少一个匹配时返回行。如果 "Persons" 中的行在 "Orders" 中没有匹配,就不会列出这些行。)

★LEFT JOIN 关键字------从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行

SELECT column_name(s)

FROM table_name1

LEFT JOIN table_name2

ON table_name1.column_name=table_name2.column_name

(注:在某些数据库中, LEFT JOIN 称为 LEFT OUTER JOIN。)

eg:

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

FROM Persons

LEFT JOIN Orders

ON Persons.Id_P=Orders.Id_P

ORDER BY Persons.LastName(我们希望列出所有的人,以及他们的定购 - 如果有的话)

★RIGHT JOIN 关键字------从右表 (table_name2) 那里返回所有的行,即使在左表 (table_name1) 中没有匹配的行

SELECT column_name(s)

FROM table_name1

RIGHT JOIN table_name2

ON table_name1.column_name=table_name2.column_name

(注:在某些数据库中, RIGHT JOIN 称为 RIGHT OUTER JOIN)

eg:

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

FROM Persons

RIGHT JOIN Orders

ON Persons.Id_P=Orders.Id_P

ORDER BY Persons.LastName(我们希望列出所有的定单,以及定购它们的人 - 如果有的话)

★FULL JOIN 关键字------只要存在匹配,FULL JOIN 关键字就会返回两个匹配表中的所有行

SELECT column_name(s)

FROM table_name1

FULL JOIN table_name2

ON table_name1.column_name=table_name2.column_name

(注:在某些数据库中, FULL JOIN 称为 FULL OUTER JOIN)

eg:SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo

FROM Persons

FULL JOIN Orders

ON Persons.Id_P=Orders.Id_P

ORDER BY Persons.LastName(我们希望列出所有的人,以及他们的定单,以及所有的定单,以及定购它们的人)

(注:FULL JOIN 关键字会从左表 (Persons) 和右表 (Orders) 那里返回所有的行。如果 "Persons" 中的行在表 "Orders" 中没有匹配,或者如果 "Orders" 中的行在表 "Persons" 中没有匹配,这些行同样会列出。)

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

1.UNION 命令

SELECT column_name(s) FROM table_name1

UNION

SELECT column_name(s) FROM table_name2

eg:

SELECT E_Name FROM Employees_China

UNION

SELECT E_Name FROM Employees_USA(列出所有在中国和美国的不同的雇员名,)

(注:这个命令无法列出在中国和美国的所有雇员。在上面的例子中,当有两个名字相同的雇员,他们当中只有一个人会被列出来。UNION 命令只会选取不同的值。)

2.UNION ALL

UNION ALL 命令和 UNION 命令几乎是等效的,不过 UNION ALL 命令会列出所有的值。

SELECT column_name(s) FROM table_name1

UNION ALL

SELECT column_name(s) FROM table_name2

eg:

SELECT E_Name FROM Employees_China

UNION ALL

SELECT E_Name FROM Employees_USA(列出在中国和美国的所有的雇员,含名字相同的)

(✪✪注:UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。默认地,UNION 操作符选取不同的值。如果允许重复的值,请使用 UNION ALL。UNION 结果集中的列名总是等于 UNION 中第一个 SELECT 语句中的列名)

★SELECT INTO 语句-------用于创建表的备份复件,或者用于对记录进行存档。

功能:从一个表中选取数据,然后把数据插入另一个表中

1.把所有的列插入新表:

SELECT *

INTO new_table_name [IN externaldatabase]

FROM old_tablename

eg:

SELECT *

INTO Persons_backup

FROM Persons(制作 "Persons" 表的备份复件)

eg:

SELECT *

INTO Persons IN 'Backup.mdb'

FROM Persons(IN 子句可用于向另一个数据库中拷贝表)

2.只把希望的列插入新表

我们希望拷贝某些域,可以在 SELECT 语句后列出这些域

SELECT column_name(s)

INTO new_table_name [IN externaldatabase]

FROM old_tablename

eg:

SELECT LastName,FirstName

INTO Persons_backup

FROM Persons

eg:

我们也可以添加 WHERE 子句

SELECT LastName,Firstname

INTO Persons_backup

FROM Persons

WHERE City='Beijing'(从 "Persons" 表中提取居住在 "Beijing" 的人的信息,创建了一个带有两个列的名为 "Persons_backup" 的表)

eg:

从一个以上的表中选取数据也是可以做到的。

SELECT Persons.LastName,Orders.OrderNo

INTO Persons_Order_Backup

FROM Persons

INNER JOIN Orders

ON Persons.Id_P=Orders.Id_P(创建一个名为 "Persons_Order_Backup" 的新表,其中包含了从 Persons 和 Orders 两个表中取得的信息)

★CREATE DATABASE语句-----用于创建数据库

CREATE DATABASE database_name

CREATE DATABASE my_db(创建一个名为 "my_db" 的数据库)

★CREATE TABLE 语句------用于创建数据库中的表

CREATE TABLE 表名称

(

列名称1 数据类型,

列名称2 数据类型,

列名称3 数据类型,

....

)

SQL中最常用的数据类型:


eg:

CREATE TABLE Persons

(

Id_P int,

LastName varchar(255),

FirstName varchar(255),

Address varchar(255),

City varchar(255)

)

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

推荐阅读更多精彩内容