{MySQL} 数据库约束& 表的关系& 新增&&删除& 修改& 查询
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
- 前言
- 一、数据库约束
- 1.1约束类型:
- 1.2 NULL约束
- 1.3unique 唯一约束
- 1.4 DEFAULT:默认值约束
- 1.5 PRIMARY KEY:主键约束
- 1.6 FOREIGN KEY:外键约束
- 1.7 CHECK约束
- 二、新增
- 三.查询
- 3.1查询
- 3.2.GROUP BY子句
- 3.3HAVING
- 四、 联合查询
- 4.1 内连接
- 4.2外连接
- 4.3区别:
- 4.4合并查询
- 总结
前言
提示:这里可以添加本文要记录的大概内容:
承接上文,继续讲一下MySQL
提示:以下是本篇文章正文内容,下面案例可供参考
一、数据库约束
1.1约束类型:
NOT NULL - 指示某列不能存储 NULL 值。
UNIQUE - 保证某列的每行必须有唯一的值。
DEFAULT - 规定没有给列赋值时的默认值。
PRIMARY KEY - NOT NULL 和 UNIQUE 的结合。确保某列(或两个列多个列的结合)有唯一标
识,有助于更容易更快速地找到表中的一个特定的记录。
FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。
CHECK - 保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略CHECK子句。
1.2 NULL约束
DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT NOT NULL, sn INT, name VARCHAR(20), qq_mail VARCHAR(20) );
1.3unique 唯一约束
-- 重新设置学生表结构 DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT NOT NULL, sn INT UNIQUE, name VARCHAR(20), qq_mail VARCHAR(20) );
1.4 DEFAULT:默认值约束
DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT NOT NULL, sn INT UNIQUE, name VARCHAR(20) DEFAULT 'unkown', qq_mail VARCHAR(20) );
1.5 PRIMARY KEY:主键约束
DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT NOT NULL PRIMARY KEY, sn INT UNIQUE, name VARCHAR(20) DEFAULT 'unkown', qq_mail VARCHAR(20) );
可以用auto_increment
-- 主键是 NOT NULL 和 UNIQUE 的结合,可以不用 NOT NULL id INT PRIMARY KEY auto_increment,
1.6 FOREIGN KEY:外键约束
外键用于关联其他表的主键或唯一键
CREATE TABLE classes ( id INT PRIMARY KEY auto_increment, name VARCHAR(20), `desc` VARCHAR(100) );
DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT PRIMARY KEY auto_increment, sn INT UNIQUE, name VARCHAR(20) DEFAULT 'unkown', qq_mail VARCHAR(20), classes_id int, FOREIGN KEY (classes_id) REFERENCES classes(id) );
1.7 CHECK约束
drop table if exists test_user; create table test_user ( id int, name varchar(20), sex varchar(1), check (sex ='男' or sex='女') );
二、新增
DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT PRIMARY KEY auto_increment, sn INT UNIQUE, name VARCHAR(20) DEFAULT 'unkown', qq_mail VARCHAR(20), classes_id int, FOREIGN KEY (classes_id) REFERENCES classes(id) )
DROP TABLE IF EXISTS test_user; CREATE TABLE test_user ( id INT primary key auto_increment, name VARCHAR(20) comment '姓名', age INT comment '年龄', email VARCHAR(20) comment '邮箱', sex varchar(1) comment '性别', mobile varchar(20) comment '手机号' ); -- 将学生表中的所有数据复制到用户表 insert into test_user(name, email) select name, qq_mail from student;
三.查询
3.1查询
写俩个
//数学成绩总分 SELECT SUM(math) FROM exam_result; -- 不及格
SELECT AVG(chinese + math + english) 平均总分 FROM exam_result;
3.2.GROUP BY子句
代码如下(示例):
create table emp( id int primary key auto_increment, name varchar(20) not null, role varchar(20) not null, salary numeric(11,2) ); insert into emp(name, role, salary) values ('马云','服务员', 1000.20), ('马化腾','游戏陪玩', 2000.99), ('孙悟空','游戏角色', 999.11), ('猪无能','游戏角色', 333.5), ('沙和尚','游戏角色', 700.33), ('隔壁老王','董事长', 12000.66);
查询每个角色的最高最低工资
select role,max(salary),min(salary),avg(salary) from emp group by role; select role,max(salary),min(salary),avg(salary) from emp group by role having avg(salary)
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理!
部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!
图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!