sql学习增删改查

基础学习笔记,跟着w3school的教程

如果之后找到了更系统的教学视频也可能会跟着视频看

sql不区分大小写

sql不一定要求每条之后都包括分号

SQL DML 和 DDL

可以把 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 使用单引号来环绕文本值(大部分数据库系统也接受双引号)。如果是数值,请不要使用引号。

sql 基础

SELECT用于选择。

关键词 DISTINCT 用于返回唯一不同的值。

WHERE 子句用于规定选择的标准。

AND 和 OR 运算符用于基于一个以上的条件对记录进行过滤。

ORDER BY 语句用于对结果集进行排序,默认按照升序,如果您希望按照降序对记录进行排序,可以使用 DESC 关键字。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
SELECT 列名称 FROM 表名称 //选取某一列

SELECT * FROM 表名称 //'*'指代选取所有列

SELECT DISTINCT 列名称 FROM 表名称 //希望仅仅列出不同(distinct)的值

SELECT 列名称 FROM 表名称 WHERE 列 运算符 值 //如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句

SELECT * FROM Persons WHERE City='Beijing'

SELECT * FROM Persons WHERE FirstName='Thomas' AND LastName='Carter'

SELECT * FROM Persons WHERE firstname='Thomas' OR lastname='Carter'

SELECT * FROM Persons WHERE (FirstName='Thomas' OR FirstName='William')
AND LastName='Carter'

SELECT Company, OrderNumber FROM Orders ORDER BY Company //以字母顺序显示公司名称

SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC //以逆字母顺序显示公司名称

SELECT Company, OrderNumber FROM Orders ORDER BY Company, OrderNumber //以字母顺序显示公司名称(Company),并以数字顺序显示顺序号(OrderNumber)

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

1
2
3
INSERT INTO 表名称 VALUES (值1, 值2,....)

INSERT INTO table_name (列1, 列2,...) VALUES (值1, 值2,....) //指定所要插入数据的列

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

1
2
3
UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值

UPDATE Person SET FirstName = 'Fred' WHERE LastName = 'Wilson'

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

1
2
3
4
5
6
7
DELETE FROM 表名称 WHERE 列名称 = 值

DELETE FROM Person WHERE LastName = 'Wilson' //删除wilson所在行

DELETE FROM table_name //可以在不删除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的

DELETE * FROM table_name //同上
# 笔记

Comments

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×