1 Star 0 Fork 44

薛晖/3班SQL_Server笔记

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
笔记o 6.63 KB
一键复制 编辑 原始数据 按行查看 历史
胡江雄 提交于 2022-03-20 16:29 . QQ
 一些重要的 SQL 命令:
SELECT - 从数据库中提取数据
UPDATE - 更新数据库中的数据
DELETE - 从数据库中删除数据
INSERT INTO - 向数据库中插入新数据
CREATE DATABASE - 创建新数据库
ALTER DATABASE - 修改数据库
CREATE TABLE - 创建新表
ALTER TABLE - 变更(改变)数据库表
DROP TABLE - 删除表
CREATE INDEX - 创建索引(搜索键)
DROP INDEX - 删除索引
SELECT 语句用于从数据库中选取数据,结果被存储在一个结果表中,称为结果集。
  SQL SELECT 语法:
SELECT column_name,column_name
FROM table_name;
  与
SELECT * FROM table_name;
  本文中,我们使用众所周知的 Northwind 样本数据库进行举例介绍。下面是选自 "Customers" 表的数据:
CustomerID CustomerName ContactName Address City PostalCode Country
1
Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico
4 Around the Horn Thomas Hardy 120 Hanover Sq. London WA1 1DP UK
5 Berglunds snabbk?p Christina Berglund Berguvsv?gen 8 Lule? S-958 22 Sweden
  下面的 SQL 语句从 "Customers" 表中选取 "CustomerName" 和 "City" 列:
SELECT CustomerName,City FROM Customers;
  下面的 SQL 语句从 "Customers" 表中选取所有列:
SELECT * FROM Customers;
  在表中,一个列可能会包含多个重复值,有时也许希望仅仅列出不同(distinct)的值。DISTINCT 关键词用于返回唯一不同的值。
  SQL SELECT DISTINCT 语法:
SELECT DISTINCT column_name,column_name
FROM table_name;
回到顶部
4 SQL WHERE语句
  WHERE 子句用于提取那些满足指定标准的记录。
  SQL WHERE语法:
SELECT column_name,column_name
FROM table_name
WHERE column_name operator value;
  下面的 SQL 语句从 "Customers" 表中选取国家为 "Mexico" 的所有客户:
SELECT * FROM Customers
WHERE Country='Mexico';
  SQL 使用单引号来环绕文本值(大部分数据库系统也接受双引号)。如果是数值字段,请不要使用引号。
SELECT * FROM Customers
WHERE CustomerID=1;
  WHERE 子句中的运算符
  下面的运算符可以在 WHERE 子句中使用:
运算符 描述
= 等于
<>
不等于。
注释:在 SQL 的一些版本中,该操作符可被写成 !=
> 大于
< 小于
>= 大于等于
<= 小于等于
BETWEEN 在某个范围内
LIKE 搜索某种模式
IN 指定针对某个列的多个可能值
回到顶部
5 SQL AND与OR关键字
  AND & OR 运算符用于基于一个以上的条件对记录进行过滤。
  下面的 SQL 语句从 "Customers" 表中选取国家为 "Germany" 且城市为 "Berlin" 的所有客户:
SELECT * FROM Customers
WHERE Country='Germany'
AND City='Berlin';
  下面的 SQL 语句从 "Customers" 表中选取城市为 "Berlin" 或者 "München" 的所有客户:
SELECT * FROM Customers
WHERE City='Berlin'
OR City='München';
  下面的 SQL 语句从 "Customers" 表中选取国家为 "Germany" 且城市为 "Berlin" 或者 "München" 的所有客户:
SELECT * FROM Customers
WHERE Country='Germany'
AND (City='Berlin' OR City='München');
回到顶部
6 SQL ORDER BY关键字
  ORDER BY 关键字用于对结果集按照一个列或者多个列进行排序。ORDER BY 关键字默认按照升序对记录进行排序。如果需要按照降序对记录进行排序,您可以使用 DESC 关键字。
  ORDER BY语法:
SELECT column_name,column_name
FROM table_name
ORDER BY column_name,column_name ASC|DESC;
  下面的 SQL 语句从 "Customers" 表中选取所有客户,并按照 "Country" 列升序排序:
SELECT * FROM Customers
ORDER BY Country;
  下面的 SQL 语句从 "Customers" 表中选取所有客户,并按照 "Country" 列降序排序:
SELECT * FROM Customers
ORDER BY Country DESC;
  下面的 SQL 语句从 "Customers" 表中选取所有客户,并按照 "Country" 和 "CustomerName" 列排序:
SELECT * FROM Customers
ORDER BY Country,CustomerName;
回到顶部
7 SQL INSERT INTO语句
  INSERT INTO 语句用于向表中插入新记录。
  INSERT INTO 语句可以有两种编写形式。第一种形式无需指定要插入数据的列名,只需提供被插入的值即可:
INSERT INTO table_name
VALUES (value1,value2,value3,...);
  第二种形式需要指定列名及被插入的值:
INSERT INTO table_name (column1,column2,column3,...)
VALUES (value1,value2,value3,...);
  假如插入操作前的表如下所示:
CustomerID CustomerName ContactName Address City PostalCode Country
87 Wartian Herkku Pirkko Koskitalo Torikatu 38 Oulu 90110 Finland
88 Wellington Importadora Paula Parente Rua do Mercado, 12 Resende 08737-363 Brazil
89 White Clover Markets Karl Jablonski 305 - 14th Ave. S. Suite 3B Seattle 98128 USA
90 Wilman Kala Matti Karttunen Keskuskatu 45 Helsinki 21240 Finland
91 Wolski Zbyszek ul. Filtrowa 68 Walla 01-012 Poland
  我们要向 "Customers" 表中插入一个新行。我们可以使用下面的 SQL 语句:
INSERT INTO Customers (CustomerName, ContactName, Address, City, PostalCode, Country)
VALUES ('Cardinal','Tom B. Erichsen','Skagen 21','Stavanger','4006','Norway');
  执行插入操作以后的表如下所示:
CustomerID CustomerName ContactName Address City PostalCode Country
87 Wartian Herkku Pirkko Koskitalo Torikatu 38 Oulu 90110 Finland
88 Wellington Importadora Paula Parente Rua do Mercado, 12 Resende 08737-363 Brazil
89 White Clover Markets Karl Jablonski 305 - 14th Ave. S. Suite 3B Seattle 98128 USA
90 Wilman Kala Matti Karttunen Keskuskatu 45 Helsinki 21240 Finland
91 Wolski Zbyszek ul. Filtrowa 68 Walla 01-012 Poland
92 Cardinal Tom B. Erichsen Skagen 21 Stavanger 4006 Norway
lamp
注释:我们无需插入CustomerID列,它是自动更新的。
  我们也可以在指定的列插入数据。
  下面的 SQL 语句将插入一个新行,但是只在 "CustomerName"、"City" 和 "Country" 列插入数据(CustomerID 字段会自动更新):
INSERT INTO Customers (CustomerName, City, Country)
VALUES ('Cardinal', 'Stavanger', 'Norway');
  插入后的表如下所示:
CustomerID CustomerName ContactName Address City PostalCode Country
87 Wartian Herkku Pirkko Koskitalo Torikatu 38 Oulu 90110 Finland
88 Wellington Importadora Paula Parente Rua do Mercado, 12 Resende 08737-363 Brazil
89 White Clover Markets Karl Jablonski 305 - 14th Ave. S. Suite 3B Seattle 98128 USA
90 Wilman Kala Matti Karttunen Keskuskatu 45 Helsinki 21240 Finland
91 Wolski Zbyszek ul. Filtrowa 68 Walla 01-012 Poland
92 Cardinal null null Stavanger null Norway
lamp
注释:没有复制的列被自动填充为null。
回到顶部
8 SQL DELETE语句
  DELETE 语句用于删除表中的行。
  SQL DELETE 语法:
DELETE FROM table_name
WHERE some_column=some_value;
lamp
请注意 SQL DELETE 语句中的 WHERE 子句!
WHERE 子句规定哪条记录或者哪些记录需要删除。如果您省略了 WHERE 子句,所有的记录都将被删除!
  假设我们要从 "Customers" 表中删除客户 "Alfreds Futterkiste"。我们使用下面的 SQL 语句:
DELETE FROM Customers
WHERE CustomerName='Alfreds Futterkiste' AND ContactName='Maria Anders';
  您可以在不删除表的情况下,删除表中所有的行。这意味着表结构、属性、索引将保持不变:
DELETE FROM table_name;
or
DELETE * FROM table_name;
lamp
注释:在删除记录时要格外小心!因为不能重来!
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/su-liuli/shift-3---sql--server-notes.git
[email protected]:su-liuli/shift-3---sql--server-notes.git
su-liuli
shift-3---sql--server-notes
3班SQL_Server笔记
master

搜索帮助