Java web学习-SQL通用语句
SQL通用语句
- SQL语句可以单行或多行书写,以分号结尾
- 可使用空格和缩进来增强语句的可读性
- MySQL数据库的SQL语句不区分大小写,关键字建议使用大写
- 3种注释
- 单行注释:-- 注释内容 或 # 注释内容(mysql 特有)
- 多行注释:/* 注释 */
SQL分类
- DDL:操作数据库、表
- DML:增删改表中的数据
- DQL:查询表中的数据
- DCL:授权
DDL:操作数据库、表
-
操作数据库:CRUD
-
C(create):创建
-
创建数据库
- create database 数据库名称
-
创建数据库,判断不存在,再创建
- create database if not exists 数据库名称;
-
创建数据库,并指定字符集
- create database 数据库名称 character set 字符集名;
-
练习:创建db4数据库,判断是否存在,并制定字符集为gbk:
- create database if not exists db4 character set gbk;
-
-
R(Retrieve):查询
- 查询所有数据库的名称
- show databases;
- 查询某个数据库的字符集:查询某个数据库的创建语句
- show create database 数据库名称;
- 查询所有数据库的名称
-
U(Updata):修改
- 修改数据库的字符集
- alter database 数据库名称;
- 修改数据库的字符集
-
D(Delete):删除
- 删除数据库
- drop database 数据库名称;
- 判断数据库存在,存在再删除
- drop database if exists 数据库名称;
- 删除数据库
-
使用数据库
- 查询当前在使用的数据库的名称
- select database();
- 使用数据库
- use 数据库名称;
- 查询当前在使用的数据库的名称
-
-
操作表
-
C(create):创建
-
语法:
-
create table 表名(
列名1 数据类型1,
列名2 数据类型2,
…
列名n 数据类型n
);
-
注意:最后一列,不需要加逗号(,)
-
数据库类型:
- int 类型:age int,
- double:小数类型
- score double(5,2);
- date:日期,只包含年月日,yyyy-MM-dd
- datetime:日期,只包含年月日时分秒,yyyy-MM-dd HH:mm:ss
- timestamp:时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss
- 如果将来不给这个字段赋值,或者赋值为null,则默认使用当前的系统时间,来自动赋值
- varchar:字符串
- name varchar(20):姓名最大20个字符
- zhangsan 8个字符 张三 2个字符
-
-
复制表:
- create table 表名 like 被复制的表名;
-
-
R(Retrieve):查询
- 查询某个数据库中所有的表名称
- show tables;
- 查询表结构
- desc 表名;
- 查询某个数据库中所有的表名称
-
U(Updata):修改
- 修改表名
- alter table 表名 rename to 新表名;
- 修改字符集
- alter table 表名 character set 字符集名称;
- 添加一列
- alter table 表名 add 列名 数据类型;
- 修改列名称 类型
- alter table 表名 change 列名 新列名 新数据类型;
- alter table 表名 modify 列名 新数据类型;
- 删除列
- drop table 表名 drop 列名;
- 修改表名
-
D(Delete):删除
- drop table 表名;
- drop table if exists 表名;
-
使用数据库
-
- 数据库客户端图形化工具:SQLyog
DML:增删改表中数据
- 添加数据:
- 语法:
- insert into 表名(列名1,列名2,…,列名n) values(值1,值2,…,值n);
- 注意
- 列名和值要一一对应。
- 如果表名后,不定义列名,则默认给所有列添加值
- insert into 表名 values(值1,值2,…,值n);
- 除了数字类型,其他类型需要使用引号(单双都可以)引起来
- 语法:
- 删除数据:
- 语法
- delete from 表名 [where 条件];
- 注意:
- 如果不加条件,则删除表中所有记录。
- 如果要删除所有记录
- delete from 表名; —不推荐使用。有多少条记录就会执行多少次删除操作,效率比较低
- truncate table 表名; —推荐使用,效率更高,先删除表,然后再创建一张一样的空表。
- 语法
- 修改数据:
- 语法
- update 表名 set 列名1 = 值1,列名2 = 值2,…,[where 条件];
- 注意
- 如果不加任何条件,则会将表中所有记录全部删改
- 语法
DQL:查询表中的记录
select * from 表名;
-
语法:
-
select
字段列表
from
表名列表
where
条件列表
group by
分组字段
having
分组后的条件
order by
排序
limit
分页限定
-
-
基础查询
- 多个字段的查询
- select 字段名1,字段名2,…,from 表名;
- 去除重复
- select distinct 列名 from表名;
- 计算列
- 一般可以使用四则运算计算数值
- select 列名1,列名2,…,列名n,列名k+列名m from 表名;
- 如果有null参与运算,计算结果都为null
- select 列名1,列名2,…,列名n,列名k+IFNULL(列名m,0) from 表名;
- ifnull(表达式1,表达式2);
- 表达式1:哪个字段需要判断是否为null
- 表达式2:如果该字段为null后的替换值
- ifnull(表达式1,表达式2);
- 起别名
- select 列名1,列名2,…,列名n,列名k+IFNULL(列名m,0) as 别名 from 表名;
- as:也可以省略
- 多个字段的查询
-
条件查询
-
where子句后跟条件
-
运算符
- >,<,<=,>=,=,<>(<>:是不等号)
- between…and
- in(集合)
- like:模糊查询
- 占位符
- _:单个任意字符
- %:多个任意字符
- 占位符
- is null
- and 或 &&
- or 或 ||
- not 或 !
- null 值不可使用=(!=)判断
- 判断不为null 用 列名 is not null
-
排序查询
- 语法:order by 子句
- order by 排序字段1,排序方式1,排序字段2,排序方式2…
- 排序方式:
- ASC:升序,默认的
- DESC:降序
- 注意:
- 如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件
- 语法:order by 子句
-
聚合函数:将一列数据作为一个整体,进行纵向的计算。
- count:计算个数
- 一般选择非空的列:主键
- count(*)
- max:计算最大值
- min:计算最小值
- sum:计算和
- avg:计算平均值
- 注意聚合函数会排除null
- 解决:
- 选择非空列进行计算
- IFNULL函数
- 解决:
- count:计算个数
-
分组查询
- 语法:
- group by 分组字段
- 注意:
- 分组之后查询的字段:分组字段、聚合函数
- where 和 having 的区别
- where 在分组之前进行限定,如果不满足条件,则不参与分组。having 在分组之后进行限定,如果不满足条件,则不会被查询出来
- where 后不可以跟聚合函数,having 后可进行聚合函数的判断
- 语法:
-
分页查询
-
语法:limit 开始的索引,查询每页的条数;
-
公式:开始的索引 = (当前的页码 - 1)* 每页显示的条数
– 每页显示3条记录
select * from student limit 0,3; --第1页
select * from student limit 3,3; --第2页
select * from student limit 6,3; --第3页
-
分页操作 limit 是一个”方言“
-
-
约束
-
概念:对表中的数据进行限定,保证数据的正确性、有效性和完整性
-
分类:
- 主键约束:primary key
- 非空约束:not null
- 唯一约束:unique
- 外键约束:foreign key
-
非空约束:not null,某一列的值不能为null
-
创建表时添加约束
create table 表名(
id int,
name varchar(20) not null --name为非空
);
-
删除非空约束
alter table 表名 modify 列名 varchar(20);
-
创建name的非空约束
alter table 表名 modify 列名 varchar(20) not null;
-
-
唯一约束:unique,某一列的值不能重复
-
语法:
创建表时添加约束
create table 表名(
id int,
name varchar(20) unique; --name唯一
);
-
注意:
唯一约束可以有多个null,
-
删除唯一约束
alter table 表名 drop index 列名;
-
在表创建完后,创建name的唯一
alter table 表名 modify 列名 varchar(20) unique;
-
-
主键约束:primary key
-
注意:
-
含义:非空且唯一
-
创建表时,添加主键约束
create table 表名(
id int primary key–给id添加主键约束
);
-
创建表后,添加主键
alter table 表名 modify 列名 int primary key;
-
删除主键
– 错误 alter table 表名 modify 列名 int;
alter table 表名 drop primary key;
-
自动增长:
-
概念:如果某一列是数值类型的,使用auto_increment可以来完成值得自动增长
-
在创建表时,添加主键约束,并且完成主键自增长
create table 表名(
id int primary key auto_increment, – 给id添加主键约束
)
-
删除自动增长
alter table 表名 modify id int;
-
添加自动增长
alter table 表名 modify 列名 int auto_increment;
-
-
外键约束:foreign key,让表和表之间产生关系,从而保证数据的正确性
-
在创建表时,可以添加外键
-
语法:
create table 表名(
…
外键列
constraint (当前表)外键名称 foreign key ((当前表)外键列名) reference 主表名称(主表中的列名称)
)
-
-
删除外键
alter table 表名 drop foreign key emp_dept_fk(外键名称);
-
添加外键
alter table employee add constraint (当前表)外键名称 foreign key ((当前表)外键列名) reference 主表名称(主表中的列名称);
-
级联操作
-
添加级联操作
语法:alter table 表名 add constraint 外键名称 foreign key (外键名称) references 主键名称(主表列名称) on update cascade on delete cascade;
-
分类
- 级联的更新:on update cascade
- 级联的删除:on delete cascade
-
-
-
-
数据库的设计
-
多表之间的关系
-
分类
- 一对一:
- 如:人和身份证
- 一对多(多对一):
- 如:部门和员工
- 多对多:
- 如:学生和课程
- 一对一:
-
实现关系:
-
一对多(多对一):
- 如:部门和员工
- 实现方式:在多的一方建立外键,指向1的一方的主键
-
多对多:
- 如:学生和课程
- 实现方式:多对多关系实现需要借助第三张中间表,中间表至少包含两个字段,这两个字段作为第三张表的外键,分别指向两张表的主键
-
一对一:
- 如:人和身份证
- 实现方式:一对一关系实现,可以在任意一方添加唯一外键指向另一方的主键
- 一般合成一张表
-
数据库设计的范式
-
概念:设计数据库时
-
分类
-
第一范式(1NF):每一列都是不可分割的原子数据项
-
第二范式(2NF):在1NF的基础上,非码属性必须完全依赖于码(在1NF基础上消除非主属性对主码的部分函数依赖)
-
几个概念
-
函数依赖:A–>B,如果通过A属性(属性组)的值,可以确定唯一B属性的值。则称B依赖于A
例如:学号–>姓名 (学号,课程名称) -->分数
-
完全函数依赖:A–>B,如果A是一个属性组,则B属性值的确定需要依赖于A属性组中所有的属性值
例如:(学号,课程名称)–>分数
-
部分函数依赖:A–>B,如果A是一个属性组,则B属性值的确定只需要依赖于A属性值中某一些值即可
例如:(学号,课程名称)–>姓名
-
传递函数依赖:A–>B,B–>C 如果通过A属性(属性组)的值,可以确定唯一B属性的值,再通过B属性(属性组)的值可以确定唯一C属性的值,则称C传递函数依赖于A
例如:学号–>系名,系名–>系主任
-
码:如果在一张表中,一个属性或属性组,被其他所有属性所完全依赖,则称这个属性(属性组)为该表的码
例如:该表中码为:(学号,课程名称)
- 主属性:码属性组中的所有属性
- 非主属性:除码属性组的属性
-
-
-
第三范式(3NF):在2NF基础上,任何非主属性不依赖于其它非主属性(在2NF基础上消除传递依赖)
-
-
-
-
只需要依赖于A属性值中某一些值即可
例如:(学号,课程名称)-->姓名
4. 传递函数依赖:A-->B,B-->C 如果通过A属性(属性组)的值,可以确定唯一B属性的值,再通过B属性(属性组)的值可以确定唯一C属性的值,则称C传递函数依赖于A
例如:学号-->系名,系名-->系主任
5. 码:如果在一张表中,一个属性或属性组,被其他所有属性所完全依赖,则称这个属性(属性组)为该表的码
例如:该表中码为:(学号,课程名称)
- 主属性:码属性组中的所有属性
- 非主属性:除码属性组的属性
3. 第三范式(3NF):在2NF基础上,任何非主属性不依赖于其它非主属性(在2NF基础上*消除传递依赖*)