目录
外键(了解即可)
方式一:在创建表的时候,增加约束
CREATE TABLE `grade`(
`gradeid` INT(10) NOT NULL AUTO_INCREMENT COMMENT'年级id',
`gradename` VARCHAR(50) NOT NULL COMMENT'年级名称',
PRIMARY KEY (`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8
--学生表的gradeid字段要去引用年级表的gradeid
--定义外键key
--给这个外键添加约束(执行引用)references引用
CREATE TABLE IF NOT EXISTS `student`(
`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` VARCHAR(30) NOT NULL DEFAULT'匿名' COMMENT '姓名',
`pwd` VARCHAR(20) NOT NULL DEFAULT'123456' COMMENT'密码',
`sex` VARCHAR(2) NOT NULL DEFAULT '女' COMMENT'性别',
`birthday` DATETIME DEFAULT NULL COMMENT'出生日期',
`gradeid` INT(10) NOT NULL COMMENT'学生的年级',
`address` VARCHAR(100) DEFAULT NULL COMMENT'家庭住址',
`emai1` VARCHAR(50) DEFAULT NULL COMMENT'邮箱',
PRIMARY KEY(`id`),
KEY `FK_gradeid` (`gradeid`),
CONSTRAINT `FK_gradeid` FOREIGN KEY (`gradeid`) REFERENCES `grade`(`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8
方式二:创建表成功后,添加外键约束
CREATE TABLE `grade`(
`gradeid` INT(10) NOT NULL AUTO_INCREMENT COMMENT'年级id',
`gradename` VARCHAR(50) NOT NULL COMMENT'年级名称',
PRIMARY KEY (`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8
CREATE TABLE IF NOT EXISTS `student`(
`id` INT(10) NOT NULL AUTO_INCREMENT COMMENT'学号',
`gradeid` INT(10) NOT NULL COMMENT'学生的年级',
`name` VARCHAR(4) NOT NULL DEFAULT'匿名' COMMENT'姓名',
`psw` INT(10) NOT NULL DEFAULT'123456' COMMENT'密码',
`sex` VARCHAR(2) NOT NULL DEFAULT'男' COMMENT'性别',
`birthday` DATETIME DEFAULT NULL COMMENT'出生日期',
`adress` VARCHAR(100) DEFAULT NULL COMMENT'家庭住址',
`email` VARCHAR(50) DEFAULT NULL COMMENT'邮箱',
PRIMARY KEY(`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8
-- 创建表的时候没有外键关系,此时想要添加
ALTER TABLE `student` ADD CONSTRAINT `FK_gradeid` FOREIGN KEY(`gradeid`) REFERENCES `grade`(`gradeid`);
-- ALTER TABLE 表名 ADD CONSTRAINT 约束名 FOREIGN KEY(作为外键的列) REFERENCES 要引用的表(要引用的字段);
以上的操作都是物理外键,数据库级别的外键,我们不建议使用!(避免数据库过多造成困扰,这里了解即可)
数据库就是单纯的表,只用来存数据,只有行(数据)和列(字段)
我们想使用多张表的数据,想使用外键(要在程序去实现)
DML语言(重点,要全部记住)
DML语言:数据操作语言
- insert
- update
- delete
添加
insert命令
语法格式:
INSERT INTO 表名(字段名) VALUES('值1'),('值2'),...
-- 插入语句(添加)
INSERT INTO `grade`(`gradename`) VALUES('大四')
-- 插入多个字段
INSERT INTO `grade`(`gradename`) VALUES('大一'),('大二')
INSERT INTO `student`(`name`,`psw`,`sex`) VALUES('小明','111111','男')
INSERT INTO `student`(`name`,`psw`,`sex`) VALUES('小红','333333','女'),('王','444444','男')
-- 字段是可以省略的,但是后面的值必须要跟字段一一对应,不能少
INSERT INTO `student` VALUES('4','大一','小李','111222','男','20001-01-01','北京','6666')
修改
update命令
语法格式:
UPDATE 表名 SET 要修改的字段 = '要修改的值',要修改的字段 = '要修改的值' WHERE 条件
要修改的值可以是一个具体的值,也可以是一个变量
-- 修改学员名字
-- 带了条件,指定条件后只修改指定信息
UPDATE `student` SET `name`='星辰' WHERE `adress`='南京'
UPDATE `student` SET `name`='辰星' WHERE `id`='3'
-- 不带条件,没有指定条件的情况下,会修改所有信息
UPDATE `student` SET `name`='星星' -- 此时所有学员姓名都会被修改为星星
-- 修改多个属性,用逗号隔开
UPDATE `student` SET `gradeid` = '3',`name` = '孙',`birthday` = '1999-02-02' WHERE `id`='6'
-- 通过多个条件定位数据
UPDATE `student` SET `name` = '李' WHERE `id` = '4' AND `sex` = '男'
条件: where 字段 操作符 '值'
操作符 | 含义 |
= | 等于 |
<>或 != | 不等于 |
> | 大于 |
< | 小于 |
<= | 小于等于 |
>= | 大于等于 |
BETWEEN 'A' AND 'B' | A到B之间 |
AND | 和,相当于&& |
OR | 或 |
删除
delete命令
语法格式:
DELETE FROM 表名 WHERE 条件
-- 删除数据(避免这样使用,会删除所有数据)
DELETE FROM `student`
-- 删除指定数据
DELETE FROM `student` WHERE `id` = '3'
truncate命令
作用:完全清空一个数据库表,但是表的结构和索引约束不会变
-- 清空数据库表
TRUNCATE `student`
delete和truncate的区别
相同点:
- 都能删除数据
- 都不会删除表结构
不同点:
- truncate 重新设置自增列 计数器会归零
- truncate 不会影响事务
- delete 不会重新设置自增列 计数器继续计数
DELETE删除的问题,重启数据库后的现象(了解即可):
- lnnoDB:自增列会重1开始(存在内存当中的,断电即失)
- MylSAM:继续从上一个自增量开始(存在文件中的,不会丢失)