MySQL

SQL简介:

DDL:操作数据库:

查询所有的数据库

SHOW DATABASES;

在这里插入图片描述
创建数据库

CREATE DATABASE 数据库名称; 

在这里插入图片描述
创建数据库(判断,如果不存在则创建)

CREATE DATABASE IF NOT EXISTS 数据库名称;

在这里插入图片描述
删除数据库

DROP DATABASE 数据库名称;

删除数据库(判断,如果存在则删除)

DROP DATABASE IF EXISTS 数据库名称;

在这里插入图片描述

DDL:操作表:

查询当前数据库下所有表名称

SHOW TABLES;

在这里插入图片描述
查询表结构

DESC 表名称;

在这里插入图片描述
创建表

CREATE TABLE 表名 ( 
字段名1 数据类型1, 
字段名2 数据类型2,
 …字段名n 数据类型n   //注意:最后一行末尾,不能加逗号
 );  

在这里插入图片描述

create table tb_user (
 		id int, 
 		username varchar(20), 
		password varchar(32)
  );

在这里插入图片描述
MySQL 支持多种类型,可以分为三类:
1.数值:

tinyint : 小整数型,占一个字节 
int : 大整数类型,占四个字节 
		eg : age int 
double : 浮点类型
 		使用格式: 字段名 double(总长度,小数点后保留的位数) 
 		eg : score double(5,2)

2.日期:

date : 日期值。只包含年月日 
		eg :birthday date : 
datetime : 混合日期和时间值。包含年月日时分秒

3.字符串:

char : 定长字符串。 
		优点:存储性能高 
		缺点:浪费空间 
eg : name char(10) 如果存储的数据字符个数不足10个,也会占10个的空间 
varchar : 变长字符串。 
		优点:节约空间 
		缺点:存储性能底 
		eg : name varchar(10) 如果存储的数据字符个数不足10个,那就数据字符个数是几就占几个的空间

案例:

需求:设计一张学生表,请注重数据类型、长度的合理性 
		1. 编号 
		2. 姓名,姓名最长不超过10个汉字 
		3. 性别,因为取值只有两种可能,因此最多一个汉字 
		4. 生日,取值为年月日 
		5. 入学成绩,小数点后保留两位 
		6. 邮件地址,最大长度不超过 64 
		7. 家庭联系电话,不一定是手机号码,可能会出现 - 等字符
		8. 学生状态(用数字表示,正常、休学、毕业...)
create table student ( 
			id int, 
			name varchar(10), 
			gender char(1), 
			birthday date, 
			score double(5,2), 
			email varchar(15), 
			tel varchar(15), 
			status tinyint 
);

删除表

DROP TABLE 表名;

删除表时判断表是否存在

DROP TABLE IF EXISTS 表名;

在这里插入图片描述
修改表名

ALTER TABLE 表名 RENAME TO 新的表名; 
-- 将表名student修改为stu 
alter table student rename to stu;

添加一列

ALTER TABLE 表名 ADD 列名 数据类型; 
-- 给stu表添加一列address,该字段类型是varchar(50) 
alter table stu add address varchar(50);

修改数据类型

ALTER TABLE 表名 MODIFY 列名 新数据类型; 
-- 将stu表中的address字段的类型改为 char(50) 
alter table stu modify address char(50);

修改列名和数据类型

ALTER TABLE 表名 CHANGE 列名 新列名 新数据类型; 
-- 将stu表中的address字段名改为 addr,类型改为varchar(50) 
alter table stu change address addr varchar(50);

删除列

ALTER TABLE 表名 DROP 列名; 
-- 将stu表中的addr字段 删除 
alter table stu drop addr;

DML:操作数据:

给指定列添加数据

INSERT INTO 表名(列名1,列名2,) VALUES(1,2,);
INSERT INTO stu (id, NAME) VALUES (1, '张三');

给全部列添加数据

INSERT INTO 表名 VALUES(1,2,);
INSERT INTO stu VALUES (2,'李四','男','1999-11-11',88.88,'lisi@itcast.cn','13888888888',1);

批量添加数据

INSERT INTO 表名(列名1,列名2,) VALUES(1,2,),(1,2,),(1,2,); 
INSERT INTO 表名 VALUES(1,2,),(1,2,),(1,2,); --省去列名是给全部添加,但是不建议这么写
INSERT INTO stu VALUES 
(2,'李四','男','1999-11-11',88.88,'lisi@itcast.cn','13888888888',1), 
(2,'李四','男','1999-11-11',88.88,'lisi@itcast.cn','13888888888',1), 
(2,'李四','男','1999-11-11',88.88,'lisi@itcast.cn','13888888888',1);

修改表数据

UPDATE 表名 SET 列名1=1,列名2=2,… WHERE 条件 ;
update stu set sex = '女' where name = '张三';

删除数据

DELETE FROM 表名 WHERE 条件 ;
-- 删除张三记录 
delete from stu where name = '张三'; 
-- 删除stu表中所有的数据 
delete from stu;

DQL:查询操作:

查询多个字段

SELECT 字段列表 FROM 表名; 
select name,age from stu;
SELECT * FROM 表名; -- 查询所有数据
select * from stu;

去除重复记录

SELECT DISTINCT 字段列表 FROM 表名;
select distinct address from stu;

起别名

AS: AS 也可以省略
select name,math as 数学成绩,english as 英文成绩 from stu; 
select name,math 数学成绩,english 英文成绩 from stu;

条件查询:
在这里插入图片描述

SELECT 字段列表 FROM 表名 WHERE 条件列表;
select * from stu where age > 20; --查询年龄大于20岁的学员信息
select * from stu where english = null; -- 这个语句是不行的 
-- null值的比较不能使用 = 或者 != 。需要使用 is 或者 is not
select * from stu where english is null; 
select * from stu where english is not null;

模糊查询:
模糊查询使用like关键字,可以使用通配符进行占位: (1)_ : 代表单个任意字符
(2)% : 代表任意个数字符

-- 查询第二个字是'花'的学员信息
select * from stu where name like '_花%';

排序查询:

SELECT 字段列表 FROM 表名 ORDER BY 排序字段名1 [排序方式1],排序字段名2 [排序方式2];

ASC : 升序排列 (默认值)
DESC : 降序排列

-- 查询学生信息,按照数学成绩降序排列,如果数学成绩一样,再按照英语成绩升序排列
select * from stu order by math desc , english asc ;

聚合函数:
将一列数据作为一个整体,进行纵向计算。
在这里插入图片描述

SELECT 聚合函数名(列名) FROM 表;
-- 注意:null 值不参与所有聚合函数运算
-- 统计班级一共有多少个学生
select count(id) from stu; 
-- 查询数学成绩的最高分
select max(math) from stu;

分组查询:

SELECT 字段列表 FROM 表名 [WHERE 分组前条件限定] GROUP BY 分组字段名 [HAVING 分组后条件过滤];
-- 查询男同学和女同学各自的数学平均分
select sex, avg(math) from stu group by sex;
-- 注意:分组之后,查询的字段为聚合函数和分组字段,查询其他字段无任何意义
select name, sex, avg(math) from stu group by sex; -- 这里查询name字段就没有任何意义
-- 查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组
select sex, avg(math),count(*) from stu where math > 70 group by sex;
-- 查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组,分组之后人数大于2个的
select sex, avg(math),count(*) from stu where math > 70 group by sex having count(*) > 2;

where 和 having 区别:
1.执行时机不一样:where 是分组之前进行限定,不满足where条件,则不参与分组,而having是分组之后对结果进行过
滤。
2.可判断的条件不一样:where 不能对聚合函数进行判断,having 可以。
分页查询:

SELECT 字段列表 FROM 表名 LIMIT 起始索引 , 查询条目数;
-- 注意: 上述语句中的起始索引是从0开始
-- 每页显示3条数据,查询第1页数据
select * from stu limit 0 , 3;
-- 每页显示3条数据,查询第2页数据
select * from stu limit 3 , 3;

从上面的练习推导出起始索引计算公式:
起始索引 = (当前页码 - 1) * 每页显示的条数

约束:

非空约束:

 NOT NULL

保证列中所有的数据不能有null值。

唯一约束:

UNIQUE

保证列中所有数据各不相同。

主键约束:

PRIMARY KEY

主键是一行数据的唯一标识,要求非空且唯一。

检查约束:

CHECK

保证列中的值满足某一条件。

验证自动增长:

auto_increment 

当列是数字类型 并且唯一约束

默认约束:

DEFAULT

保存数据时,未指定值则采用默认值。
注意:默认约束只有在不给值时才会采用默认值。如果给了null,那值就是null值。

外键约束:

-- 创建表时添加外键约束
CREATE TABLE 表名( 
    列名 数据类型,[CONSTRAINT] [外键名称] FOREIGN KEY(外键列名) REFERENCES 主表(主表列名) 
    );
-- 建完表后添加外键约束 
    ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称); 

外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性。
添加外键约束要先有主表。
在这里插入图片描述
删除外键约束:

ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;

数据库设计简介:
软件的研发步骤:在这里插入图片描述

表关系:

一对一:实现方式:在任意一方加入外键,关联另一方主键,并且设置外键为唯一(UNIQUE)
一对一关系多用于表拆分,将一个实体中经常使用的字段放一张表,不经常使用的字段放另一张表,用于提升
查询性能
在这里插入图片描述

一对多:在多的一方建立外键,指向一的一方的主键
在这里插入图片描述

多对多:建立第三张中间表,中间表至少包含两个外键,分别关联两方主键
经过分析发现,订单表和商品表都属于多的一方,此时需要创建一个中间表,在中间表中添加订单表的外键和商品表的
外键指向两张表的主键:
在这里插入图片描述

多表查询:

内连接查询:

语法:

-- 隐式内连接 SELECT 字段列表 FROM 表1,表2… WHERE 条件; 
-- 显示内连接 SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 条件;(inner可以省略)

内连接相当于查询 A B 交集数据
在这里插入图片描述
在表名后面加字母就是起别名

SELECT
	t1. NAME, 
	t1.gender, 
	t2.dname 
FROM
	emp t1, 
	dept t2 
WHERE
	t1.dep_id = t2.did;

外连接查询:

语法:

-- 左外连接 
SELECT 字段列表 FROM 表1 LEFT [OUTER] JOIN 表2 ON 条件;
 -- 右外连接 
 SELECT 字段列表 FROM 表1 RIGHT [OUTER] JOIN 表2 ON 条件;

左外连接:相当于查询A表所有数据和交集部分数据
右外连接:相当于查询B表所有数据和交集部分数据
在这里插入图片描述

子查询:

查询中嵌套查询,称嵌套查询为子查询。
在这里插入图片描述
可以先在一个表里把要查询的信息找出来,然后再看看用上面的哪个
虚拟表就是替换前面的表,如下面把emp替换了
在这里插入图片描述

事务:

概述:一组数据库操作命令,要么同时成功,要么同时失败。
在这里插入图片描述
语法:

开启事务
START TRANSACTION; 
或者
BEGIN;
提交事务:
commit;
回滚事务
rollback;

提交事务是保证更改的永久生效,回滚事务是回到BEGIN处
上面sql中的执行成功进选择执行提交事务,而出现问题则执行回滚事务的语句。以后我们肯定不可能这样操作,而是在java中进行操作,在java中可以抓取异常,没出现异常提交事务,出现异常回滚事务。

事务的四大特征:
原子性(Atomicity): 事务是不可分割的最小操作单位,要么同时成功,要么同时失败
一致性(Consistency) :事务完成时,必须使所有的数据都保持一致状态
隔离性(Isolation) :多个事务之间,操作的可见性
持久性(Durability) :事务一旦提交或回滚,它对数据库中的数据的改变就是永久的

说明:
mysql中事务是自动提交的。
也就是说我们不添加事务执行sql语句,语句执行完毕会自动的提交事务。
可以通过下面语句查询默认提交方式:

SELECT @@autocommit;

查询到的结果是1 则表示自动提交,结果是0表示手动提交。当然也可以通过下面语句修改提交方式

set @@autocommit = 0;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值