Web day2 数据库MySQL DML,事务

DML

在这里插入图片描述
当对全部列进行添加时,省略列名
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

# 添加
INSERT INTO student VALUES(100,'CC',456,'NV','1999-6=7','上海');
# 修改
UPDATE student SET `name`='gou' WHERE `adress`='上海';
# 删除
DELETE FROM student WHERE `name`='gou';
# 清空
TRUNCATE TABLE student;

数据表操作

在这里插入图片描述
在这里插入图片描述
M 总长度,D小数长度;用于确定范围
在这里插入图片描述
在这里插入图片描述
每条记录最大只能是64k;
我们使用utf8mb4,一个字符占用4个字节,varchar最大长度只能是16383;
BLOB,TEXT并不使用那64k,他们会另外开辟空间
longblob用来存储大对象,能达到几个G.

创建数据表

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

# 创建表
CREATE TABLE `subject`(
subject_id 	INT,
subject_Name VARCHAR(20),
subject_hours INT
);
# 列添加
ALTER TABLE `subject` ADD picture LONGBLOB;
# 列修改
ALTER TABLE `subject` MODIFY subject_Name VARCHAR(30);
# 删除表中列
ALTER TABLE `subject` DROP picture;
# 修改列名
ALTER TABLE  `subject` CHANGE subject_Name subject_name VARCHAR(90);
# 修改表名
ALTER TABLE `subject` RENAME sub;
# 删除表
DROP TABLE sub;

约束

在这里插入图片描述

实体完整性约束

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
自动增长必须是数值类型,必须是主键,默认从1开始,自动增长1,可以设置开始位置
在这里插入图片描述

域完整性约束

在这里插入图片描述

引用完整性约束

在这里插入图片描述
引用的列必须是有主键的列

	CREATE TABLE score(
	sno INT,
	subject_id INT,
	result DOUBLE DEFAULT 60,
	exam_date DATETIME,
	// 为已创建的键添加外键
	CONSTRAINT FOREIGN KEY(sno) REFERENCES student(sno)
);

事务

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

使用隐式事务,客户端一连接默认开启事务,每次执行事务都会自动提交或回滚,然后再次开启事务
使用显式事务,显示手动开启事务,不会自动提交或者回滚

每条语句都是一个独立的事务
在这里插入图片描述
显示开启事务只影响一次,提交后后面的操作仍会自动提交
SET AUTOCOMMIT = 0;之后的都不会自动提交

# 显示开启事务
START TRANSACTION;
# 操作
UPDATE bank SET money=money-1000 WHERE id=1;
UPDATE bank SET money=money+1000 WHERE id=2;
SELECT money FROM bank;
# 显示回滚
ROLLBACK;
# 显示提交
COMMIT;

在这里插入图片描述

权限管理

root账户只有本地能使用
在这里插入图片描述

# 创建普通账号
CREATE USER chichi IDENTIFIED BY '5978521';
# 授权 ALL 所有权限
GRANT ALL ON chichi.vm_chichi TO chichi;
# 撤销权限
REVOKE ALL ON chichi.vm_chichi FROM chichi;
# 删除用户
DROP USER chichi;

视图

一般仅用于查询
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值