数据库知识点自我补充
SQL (Structure Query Language)
1.RDBMS 指的是关系型数据库管理系统,可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL)。
2.增删改查构成了SQL的DML部分,而DLL部分如下:
SQL 中最重要的 DDL 语句:
- CREATE DATABASE - 创建新数据库
- ALTER DATABASE - 修改数据库
- CREATE TABLE - 创建新表
- ALTER TABLE - 变更(改变)数据库表
- DROP TABLE - 删除表
- CREATE INDEX - 创建索引(搜索键)
- DROP INDEX - 删除索引
第一部分 SQL 基本语句
关键词 DISTINCT 用于返回唯一不同的值。
SELECT DISTINCT 列名称 FROM 表名称
引号的使用
请注意,我们在例子中的条件值周围使用的是单引号。
这是正确的: SELECT * FROM Persons WHERE FirstName='Bush' 这是错误的: SELECT * FROM Persons WHERE FirstName=Bush
Order by的使用
以字母顺序显示公司名称(Company),并以数字顺序显示顺序号(OrderNumber):
SELECT Company, OrderNumber FROM Orders ORDER BY Company, OrderNumber
这句话是说,查询公司名和序号,首先按照公司的名称进行排序,如果相同,则按照顺序号升序排序,(升序为ASC, 降序为DESC)
Update 语句
UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值
DELETE 语句
DELETE FROM 表名称 WHERE 列名称 = 值
第二部分 SQL 高级语句
TOP 子句
TOP 子句用于规定要返回的记录的数目。
Sql Server中使用top语法为:select top 10 列名 from 表 (显示表的前10条数据) select top 50 percent 列名 from 表(显示标的百分之50的数据) Mysql中,使用的是limit,相同功能的语法为:select 列名 from 表 limit 10 Oracle中使用的是rownum,表示行数,select 列名 from 表 where rownum <=10
SQL 通配符
现在,我们希望从上面的 "Persons" 表中选取居住的城市以 "A" 或 "L" 或 "N" 开头的人:
SELECT * FROM Persons WHERE City LIKE '[ALN]%'
//in操作,表示允许我们在Where中规定多个值
SELECT column_name(s) FROM table_name WHERE column_name IN (value1,value2,...) //column_name列名为任意一个均能查出
BETWEEN 操作符
操作符 BETWEEN ... AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期。
重要事项:(between and的区间的左右开闭情况,对于不同数据库有不同的规定)不同的数据库对 BETWEEN...AND 操作符的处理方式是有差异的。某些数据库会列出介于 "Adams" 和 "Carter" 之间的人,但不包括 "Adams" 和 "Carter" ;某些数据库会列出介于 "Adams" 和 "Carter" 之间并包括 "Adams" 和 "Carter" 的人;而另一些数据库会列出介于 "Adams" 和 "Carter" 之间的人,包括 "Adams" ,但不包括 "Carter" 。
【还可以用Not操作符表示不在某个范围内的记录,where lastname not between ‘Adams’ and ‘Carter’】
SQL JOIN
SQL join 用于根据两个或多个表中的列之间的关系,从这些表中查询数据。
下面列出了您可以使用的 JOIN 类型,以及它们之间的差异。
- JOIN: 如果表中有至少一个匹配,则返回行
- LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行
- RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
- FULL JOIN: 只要其中一个表中存在匹配,就返回行
SQL UNION 操作符
UNION 操作符用于合并两个或多个 SELECT 语句的结果集。
请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。
SELECT column_name(s) FROM table_name1 UNION ALL // UNION表示选取不同的值,All允许重复值 SELECT column_name(s) FROM table_name2
SELECT INTO 语句
SELECT INTO 语句从一个表中选取数据,然后把数据插入另一个表中。
SELECT INTO 语句常用于创建表的备份复件或者用于对记录进行存档。
SELECT * INTO new_table_name [IN externaldatabase] FROM old_tablename
实例:在Mysql中,执行上述语句,如下所示:
SELECT `姓名`,`学号` INTO new_table from student LIMIT 4
[Err] 1327 - Undeclared variable: new_table
报错原因:mysql 数据库是不支持 SELECT INTO FROM 这种语句,采用如下方式进行创建即可
CREATE table new_table (SELECT `姓名`,`学号` from student LIMIT 4)
SQL 约束
约束用于限制加入表的数据的类型。
我们将主要探讨以下几种约束:
- NOT NULL 约束强制列不接受 NULL 值
- UNIQUE 约束唯一标识数据库表中的每条记录。
- 当表已被创建时,如需在 "Id_P" 列创建 UNIQUE 约束,请使用下列 SQL:
ALTER TABLE Persons //更改表,增加unique约束 ADD UNIQUE (Id_P)
ALTER TABLE Persons DROP INDEX uc_PersonID //删除unique约束
- 当表已被创建时,如需在 "Id_P" 列创建 UNIQUE 约束,请使用下列 SQL:
- PRIMARY KEY UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。
- (请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束)
-
CREATE TABLE Persons ( Id_P int NOT NULL, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255), CONSTRAINT pk_PersonID PRIMARY KEY (Id_P,LastName) //命名 PRIMARY KEY 约束,以及为多个列定义 PRIMARY KEY 约束 )
- FOREIGN KEY ()
- 一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY
-
CREATE TABLE Orders ( Id_O int NOT NULL, OrderNo int NOT NULL, Id_P int, PRIMARY KEY (Id_O), FOREIGN KEY (Id_P) REFERENCES Persons(Id_P) //本表的外键Id_p为Person表中的主键Id_p )
- CHECK
-
CHECK 约束用于限制列中的值的范围。
如果对单个列定义 CHECK 约束,那么该列只允许特定的值。
如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限制。
-
CREATE TABLE Persons ( Id_P int NOT NULL, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255), CHECK (Id_P>0) //约束Id_p必须大于0 //当约束多个列时,CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes') )
-
- DEFAULT (DEFAULT 约束用于向列中插入默认值
-
CREATE TABLE Orders ( Id_O int NOT NULL, OrderNo int NOT NULL, Id_P int DEFAULT 100, //默认值为100 OrderDate date DEFAULT GETDATE() //日期默认值为当前 )
-
//更改Persons表中的City列的默认值为SANDNES ALTER TABLE Persons ALTER City SET DEFAULT 'SANDNES'
-
SQL 索引
CREATE INDEX 语句用于在表中创建索引。(用户无法看到索引,它们只能被用来加速搜索/查询。)
在不读取整个表的情况下,索引使数据库应用程序可以更快地查找数据。
(注释:更新一个包含索引的表需要比更新一个没有索引的表更多的时间,这是由于索引本身也需要更新。因此,理想的做法是仅仅在常常被搜索的列(以及表)上面创建索引)
CREATE UNIQUE INDEX index_name //unique表示唯一的索引,如果不加此关键词,则允许重复值 ON table_name (column_name)
Drop ————通过使用 DROP 语句,可以轻松地删除索引、表和数据库。
以mysql为例,基本语法均为:“更改表+如何更改”
例如:
ALTER TABLE table_name DROP INDEX index_name
Drop table为删除表,truncate teble为删除表内数据,但是不删除表本身
ALTER TABLE 语句
ALTER TABLE 语句用于在已有的表中添加、修改或删除列。
//在表中,增加一列paiming,数据类型为varchar类型
ALTER TABLE student ADD paiming VARCHAR(20)
//删除表中的某一列,需指出删除的是列COLUMN
ALTER TABLE table_name DROP COLUMN column_name
//修改表中的某一列。
ALTER TABLE table_name ALTER COLUMN column_name datatype
AUTO INCREMENT 字段
我们通常希望在每次插入新记录时,自动地创建主键字段的值。
我们可以在表中创建一个 auto-increment 字段。
CREATE TABLE Persons ( P_Id int NOT NULL AUTO_INCREMENT, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255), PRIMARY KEY (P_Id) )
默认地,AUTO_INCREMENT 的开始值是 1,每条新记录递增 1,可以使用alter关键字对其初始值进行更改
alter table Persons auto_increment=100 表示,auto_increment的初始值为100
SQL VIEW(视图) 视图是可视化的表。
什么是视图?
在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表。
视图包含行和列,就像一个真实的表。视图中的字段就是来自一个或多个数据库中的真实的表中的字段。我们可以向视图添加 SQL 函数、WHERE 以及 JOIN 语句,我们也可以提交数据,就像这些来自于某个单一的表。
注释:数据库的设计和结构不会受到视图中的函数、where 或 join 语句的影响。
创建视图
create view view_name as select column_name from table_name where condition
注释:视图总是显示最近的数据。每当用户查询视图时,数据库引擎通过使用 SQL 语句来重建数据。
//等待后续补充......
MySQL Date 函数
事实证明, 在Mysql中,datetime类型存在问题,需要将datetime换成timestamp类型
EXTRACT() 函数
EXTRACT() 函数用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等。
SELECT EXTRACT(YEAR FROM OrderDate) AS OrderYear, EXTRACT(MONTH FROM OrderDate) AS OrderMonth, EXTRACT(DAY FROM OrderDate) AS OrderDay, EXTRACT(MINUTE FROM OrderDate) AS OrderMin FROM Orders
Date_Add()函数:给定日期添加指定的时间间隔(Date_Sub是减法),如图所示,将原来的时间,增加两天,进行更新
DATEDIFF() 函数:返回两个日期之间的天数。
DATE_FORMAT() 函数:显示不同的格式
重点记:
SELECT * from orders where DATE(OrderDate) ='2019-09-12' //DATE提取OrderDate中的日期部分 SELECT * from orders where EXTRACT(YEAR FROM OrderDate) ='2019' //extract提取OrderDate中对应单元,即YEAR、MONTH、DAY等单元
IS NULL 和 IS NOT NULL 操作符。
表示允许其是不是为空
DBMS - 数据库管理系统(Database Management System)
RDBMS - 关系数据库管理系统(Relational Database Management System)
第三部分 SQL 函数
SQL 拥有很多可用于计数和计算的内建函数。
两种:1Aggregate函数2Scalar函数
AVG()计算某字段的平均值
SELECT AVG(OrderPrice) AS OrderAverage FROM Orders
COUNT() 函数返回匹配指定条件的行数
SELECT COUNT(column_name) FROM table_name
SELECT COUNT(*) FROM table_name 这句话显示表中的记录数
COUNT(DISTINCT column_name) 函数返回指定列的不同值的数目
FIRST() 函数返回指定的字段中第一个记录的值。
然而,在Mysql中是不支持First函数的,采用limit来实现第一条或前几条记录
同样,在mysql中,Last函数也不支持,可以采用逆序,选取Limit进行实现
SUM 函数返回数值列的总数(总额)。
注意:Sum函数是求和,而count函数是统计记录数目
Group By语句 GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组。
SELECT Customer,SUM(OrderPrice) FROM Orders GROUP BY Customer //返回每个顾客的总消费金额,这样的话,采用Groupby对客户进行分组
HAVING 子句
在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与合计函数一起使用。
那么having语句也是限定条件,到底和Where有什么不同呢??????????????
根据上边红色部分的字,Where只能修饰返回的单一值,不能和合计函数一起用,因此,但对合计函数进行限定时,需采用having进行修饰!!!
SELECT Customer,SUM(OrderPrice) FROM Orders GROUP BY Customer HAVING SUM(OrderPrice)<2000 //比如这个,查找订单总金额少于 2000 的客户。
UCASE() 和LCASE()函数,是将字段的值转换为大小写
MID() 函数
MID 函数用于从文本字段中提取字符。(感觉这个函数应该用处不小)
语法:
SELECT MID(column_name,start[,length]) FROM table_name
LEN() 函数
LEN 函数返回文本字段中值的长度。
注意:在MySQL中,对应的函数为LENGTH(str)函数,如下:
ROUND() 函数
ROUND 函数用于把数值字段舍入为指定的小数位数。
亲测:如果所查列中,小数位数为1位,你想保留两位,它不会自动补零!!!
基本的语句和语法就这些了!!!期待更多的内容~