MySQL数据管理

目录

外键(了解即可)

DML语言(重点,要全部记住)

添加

insert命令

修改

update命令

删除 

 delete命令

 truncate命令

delete和truncate的区别


外键(了解即可)

方式一:在创建表的时候,增加约束

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:继续从上一个自增量开始(存在文件中的,不会丢失)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值