当前位置: 首页 > news >正文

【JavaWeb】MySQL约束、事务、多表查询

1 约束

PRIMARY KEY

主键约束

UNIQUE

唯一约束

NOT NULL

非空约束

DEFAULT

默认值约束

FOREIGN KEY

外键约束

主键

主键值必须唯一且非空;每个表必须有一个主键

建表时主键约束

CREATE TABLE 表名 (字段名 字段类型 PRIMARY KEY,字段名 字段类型
);CREATE TABLE 表名(列名 数据类型,[CONSTRAINT] [约束名称] PRIMARY KEY(列名)
); 

建表后单独添加主键

ALTER TABLE 表名 ADD PRIMARY KEY (字段名);

删除主键约束

ALTER TABLE 表名 DROP PRIMARY KEY;

主键自增

在每次插入新数据时,数据库自动生成主键字段的值(字段类型必须是数值类型)

建表时:

CREATE TABLE 表名 (字段名 字段类型 PRIMARY KEY AUTO_INCREMENT,字段名 字段类型
);

自增字段在省略字段名插入时,可以给个表中没有的主键数值,也可以用null做占位符,如果没有占位,直接省略不写会报错

修改自动增长的开始值

ALTER TABLE 表名 AUTO_INCREMENT = 要修改的数值;

唯一约束

唯一约束作用:让字段值唯一,不能重复

CREATE TABLE 表名 (字段名 字段类型 UNIQUE,字段名 字段类型
);

非空约束作用:让字段值不能为null

CREATE TABLE 表名 (字段名 字段类型 NOT NULL,字段名 字段类型
);

默认值约束作用:如果这个字段不设置值,用默认值

CREATE TABLE 表名 (字段名 字段类型 DEFAULT 值,字段名 字段类型
);

主键时唯一且非空,约束也可以唯一且非空区别:主键一个表只有一个,约束可以约束多个键

外键

外键:一个表中的引用其它表中的主键的字段

CREATE TABLE 表名 (字段名 字段类型,字段名 字段类型,-- 添加外键约束CONSTRAINT 外键约束名 FOREIGN KEY(外键字段名) REFERENCES 主表(主键字段名)
);
  • CONSTRAINT表示约束外键约束名,给外键约束取个名字,将来通过约束名可以删除这个约束
  • FOREIGN KEY(外键字段名):  指定某个字段作为外键
  • REFERENCES 主表(主键字段名) :  引用主表的主键的值

在存在的表添加外键约束([]内可以省略不写)

ALTER TABLE 从表 ADD [CONSTRAINT 外键约束名称] FOREIGN KEY(外键字段名) REFERENCES 主表(主键字段名);

删除外键约束

ALTER TABLE 表名 DROP FOREIGN KEY 外键约束名;

2 事务

-- 开启事务
START TRANSACTION; 或者  BEGIN;
-- 提交事务
COMMIT;
-- 回滚事务
ROLLBACK;

事务特性

原子性(Atomicity

事务是不可分割的最小操作单位,要么同时成功,要么同时失败

一致性(Consistency

事务前后数据的完整性必须保持一致。

隔离性(Isolation

是指多个事务并发访问数据库时,一个事务不能被其它的事务所干扰,多个并发事务之间数据要相互隔离,不能相互影响。

持久性(Durability

事务一旦提交或回滚,它对数据库中的数据的改变就是永久的

默认事务是自动提交的

 -- 查看MySQL是否开启自动提交事务
SELECT @@autocommit;-- 关闭自动提交事务
set autocommit = 0;

3 多表查询

内连接:不显示不满足条件的数据

隐式内连接

SELECT 字段列表 FROM 表1 [别名],表2 [别名]… WHERE 条件;

 显示内连接(INNER JOIN ... ON)

SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 条件;
select * from 表1 inner join 表2 on 表连接条件 where 查询条件;

外连接

左外连接:查询出满足条件的数据和表1其余数据

左外连接:查询出满足条件的数据和表2其余数据

--左外连接格式
SELECT * FROM 表1 LEFT OUTER JOIN 表2 ON 表连接条件 WHERE 查询条件;
--右外连接格式
SELECT * FROM 表1 RIGHT OUTER JOIN 表2 ON 表连接条件 WHERE 查询条件;

子查询

先执行子查询,将子查询的结果作为父查询的一部分

in; not in; exists

SELECT 查询字段 FROM 表 WHERE 条件;
--例子,单行单列,括号里面是子查询
SELECT * FROM employee WHERE salary=(SELECT MAX(salary) FROM employee);
-- 多行单列,多行数据但是查询的是同一列 in/any/all
SELECT 查询字段 FROM 表 WHERE 字段 IN (子查询);
--多行多列,from后是子查询
SELECT 查询字段 FROM (子查询) 表别名 WHERE 条件;

多行单列 

 多行多列

-- aaa是子查询数据的别名
select * from (select * from Student where age >= 18) aaa left outer join class on aaa.classid = class.id

http://www.lryc.cn/news/124732.html

相关文章:

  • 【并发编程】自研数据同步工具优化:创建线程池多线程异步去分页调用其他服务接口获取海量数据
  • 七、dokcer-compose部署springboot的jar
  • k8s 使用 containerd 运行时配置 http 私服
  • 【新品发布】ChatWork企业知识库系统源码
  • 疫情打卡 vue+springboot疾病防控管理系统java jsp源代码
  • python --连接websocket
  • 数据库内日期类型数据大于小于条件查找注意事项
  • 网易有道押宝大模型,打响智能硬件突围战
  • KAFKA第二课之生产者(面试重点)
  • Mybatis 源码 ∞ :杂七杂八
  • 堆的实现以及应用
  • MySql011——检索数据:过滤数据(使用正则表达式)
  • 数据结构与算法-栈(LIFO)(经典面试题)
  • NSI45030AT1G LED驱动器方案为汽车外部及内部照明恒流稳流器(CCR)方案
  • uni-app中使用pinia
  • Spring之事务管理
  • linux常见的mysql问题
  • 常见分辨率时序信息
  • 机器人CPP编程基础-05完结The End
  • 数据库应用系统DBAS功能设计与实施(三级数据库)
  • 快速幂典型
  • 计算机竞赛 python+opencv+机器学习车牌识别
  • 解决电脑声音正常但就是某些游戏没声音问题
  • 【UniApp开发小程序】小程序首页(展示商品、商品搜索、商品分类搜索)【后端基于若依管理系统开发】
  • Redis 持久化及集群架构
  • FPGA + WS2812采灯控制
  • 【视频】使用OBS将MP4推流至腾讯云直播
  • Vue基本知识
  • item_get_sales-获取商品销量详情
  • LangChain手记 Memory