MySQL(多表查询 索引 事务 视图)

这篇博客详细探讨了MySQL数据库中的约束,包括主键、自增、非空、唯一和非负约束,以及枚举类型和外键约束的应用,如一对多和多对多关系。同时,介绍了索引的重要性和使用,事务的管理以及视图的概念和用途。通过实例解析了子查询和自连接查询,帮助读者深入掌握MySQL操作技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

约束

生活中的约束的意思:
	一种束缚,一种规则,一种限定,是你感觉不够自由

数据库中的约束:
	对我们的字段的值,进行一种规则方面的限定
	例如,这个字段的值,必须唯一,不能为null 等等

MySQL中常见的几种约束
    主键约束 primary key
    自增长约束 AUTO_INCREMENT
    非空约束 not null
    唯一约束 unique 
    外键约束 foreign key
    非负约束 unsigned
    ENUM 枚举类型,能起到约束的作用

主键约束

#主键约束 primary key 特点 非空且唯一
#而且我们强烈建议一张表中,必须要有主键
#一张表只能有有一个主键 可以是复合主键

方式一 建表时添加主键约束
#字段名称 字段类型 primary key
CREATE TABLE student(
	id INT PRIMARY KEY,
	username VARCHAR(32),
	age INT);
	
方式二 建表时添加主键约束
#primary key(字段1,字段2)
CREATE TABLE student(
	id INT,
	username VARCHAR(32),
	age INT,
	PRIMARY KEY(id));
	
方式三 建表后添加主键约束
#alter table 表名 
#	add primary key(字段名1,字段名2..);
CREATE TABLE student(
	id INT,
	username VARCHAR(32),
	age INT);
ALTER TABLE student
	ADD PRIMARY KEY(id);

方式四 联合主键 
把多个字段当做一个整体设置为主键
CREATE TABLE student(
	id INT,
	username VARCHAR(32),
	age INT);		
ALTER TABLE student 
	ADD PRIMARY KEY(id,username)
	
删除主键约束:
情况1: 这个字段,只有主键约束,分两步来删除主键约束
    第一步:这样只删除了唯一,他还有个非空约束,所以得再删除非空约束
    	alter table 表名 drop primary key;
    第二步:修改字段名还为原来的字段 加上null即可
    	alter table 表名 modify 列名 varchar(20) null;
    	
情况2: 这个字段,是一个int类型字段,既有主键约束,又有自增长约束,那么得先删除自增长约束,在删除主键约束
	第一步:删除自增长约束,其实就是修改自增长字段名和数据类型还为原来的字段名和类型
		alter table 表名 change 字段名 字段名 数据类型; #删除自增长约束
	第二步:删除主键约束
		alter table 表名 drop primary key;
	第三步:删除非空约束
		ALTER TABLE 表名 MODIFY 列名 INT NULL; #就是修改字段值可以为null	

自增长约束

#自增长约束 AUTO_INCREMENT
#配合主键约束一块来用 并且针对整数型的字段
1.被修饰的字段类型支持自增 一般int
2.自增长也可以单独使用(配合unique)
3.被修饰的字段必须是一个key 一般是primary key
4.自增长默认从1开始
    -- 修改默认的自增长开始值
    ALTER TABLE 表名 AUTO_INCREMENT = 起始值;
5.如果添加数据时 给自增长字段指定值 
  则以指定值为准 按照自增长的规则来添加数据

CREATE TABLE employee(
    #主键自增长
	id INT PRIMARY KEY AUTO_INCREMENT,
	username VARCHAR(32),
	age INT
);	

非空约束

#非空约束 not null 特点:被修饰过的字段非空

create table nn(
    id int not null,
    username varchar(32) not null
);

唯一约束

#唯一约束 unique 对null值不起作用
#一张表可以有多个unique字段

#唯一标识
#字段名称 字段类型 unique
CREATE TABLE teacher(
	id INT PRIMARY KEY,
	username VARCHAR(32) UNIQUE, #唯一约束
	age INT
);

#通过修改表 添加唯一约束
#alter table 表名 add unique(字段1,字段2); 添加的联合唯一
#alter table 表名 add unique(字段1); 给一个添加唯
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值