3.MySQL数据管理

3.1外键

方式一:

 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
 定义外键foreign 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` TIMESTAMP DEFAULT null COMMENT '出生日期',
  `gradeid` int(10) not null COMMENT '年级id',
  `address` VARCHAR(100) DEFAULT null COMMENT '地址',
  `email` 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
 ​
 /*
 学生表的gradeid要去引用年级表的gradeid
 定义外键foreign 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` TIMESTAMP DEFAULT null COMMENT '出生日期',
  `gradeid` int(10) not null COMMENT '年级id',
  `address` 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 那个表(哪个字段)
 */

3.2DML语言(数据库操作语言)

*Insert

*update

*delete

3.2.1添加(insert)

 --插入语句
 --insert into 表名([字段1][字段1][字段1]...[字段n])values(`值1`),(`值2`),(`值3`)...(`值n`)
 insert into `grade`(`gradename`)VALUES('大三') --数据和字段一一对应

注意事项:

1、所有的符号为英文符号

2、字段可以省略,但是后面插入的值要一一对应

3、可以同时插入多条数据

3.2.2修改(update)

 /*
 update 修改条件 set原来的值 = 新值
 修改多个属性,逗号隔开
 */
 --修改语句
 --update 表名 set 属性=替换属性值 where (条件)主键 = 主键值;
 update `student` set `name`='Rose' where id = 1;
 ​

条件:

where 子句 运算符 id = 某个值,大于某个值,或者在某个区间范围

操作符 含义 范围 结果
= 等于 5=6 false
!= 不等于 5!=6 true
> 大于 5>6 false
< 小于 5<6 true
>= 大于等于 5>=5 true
<= 小于等于 6<=5 false
between...and... 在什么什么之间 between 2 and 5 在2-5之间查询值
AND && 5>1 and 1>2 false
OR || 5>1 or 1>2 true

注意点:

-条件,如果没有指定则会修改所有的列

-value,是一个具体的值,也可以是一个变量

-英文符号注意

3.2.3删除(delete)

 /*
 删除数据
 delete from 表名 where 主键 = 主键值;
 */
 delete from `student` where id = 1;

TRUNCATE命令:

作用:完全清空一个数据库表,表结构和索引约束不变

 --清空student表
 truncate `student`;

相同点:都能删除数据,都不会删除表结构

不同点:

-TRUNCATE 重新设置 自增列 计数器回归零

-TRUNCATE 不会影响事务

 ​
 --TRUNCATE he delete 的区别
 create table `test`(
  `id` int(4) not null auto_increment,
  `coll` varchar(10) not null,
  primary key(`id`)
 )ENGINE = INNODB DEFAULT CHARSET = utf8
 ​
 insert into `test`(`coll`)values('1'),('2'),('3')
 ​
 delete from `test`
 ​
 truncate table `test`
 ​

MySQL数据管理的更多相关文章

  1. mysql学习【第2篇】:MySQL数据管理

    狂神声明 : 文章均为自己的学习笔记 , 转载一定注明出处 ; 编辑不易 , 防君子不防小人~共勉 ! mysql学习[第2篇]:MySQL数据管理 外键管理 外键概念 如果公共关键字在一个关系中是主 ...

  2. Mysql:MySQL数据管理

    Mysql:MySQL数据管理 外键管理 外键概念 如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键.由此可见,外键表示了两个关系之间的相关联系.以另一个关系的外键作主关 ...

  3. MySQL学习03(MySQL数据管理)

    MySQL数据管理 外键 外键概念 如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键.由此可见,外键表示了两个关系之间的相关联系.以另一个关系的外键作主关键字的表被称为主 ...

  4. (三)MySQL数据管理

    3.1 外键(了解即可) 方式一:在创建表的时候,增加约束(麻烦,比较复杂) CREATE TABLE IF NOT EXISTS `student`( `id` INT(4) NOT NULL AU ...

  5. MySQL(3)— 数据管理

    三.MySQL数据管理(DML) 3-1.外键(了解即可) ALTER TABLE `aa表名` ADD CONSTRAINT `约束名` FOREIGN KEY (字段名) REFERENCES ` ...

  6. MySQL入门看这一篇就够了

    MySQL JavaEE:企业级Java开发 web阶段 分为1.前端(页面,展示数据库中的数据) 2.后台(连接点:链接数据库JDBC.Mybatis,链接前端(控制视图跳转,给前端传递数据)) 3 ...

  7. Mysql数据库值的添加、修改、删除及清空

    3.MySQL数据管理 第一种方式:不太建议,看起来复杂些 -- 学生表的 gradeid 字段,要去引用 年级表的 gradeid -- 定义外键key -- 给这个外键添加约束,(执行引用),RE ...

  8. mysql语法使用详细代码版

    mysql 1.什么是数据库 数据库:(DB,DataBase) 作用:用来存储数据,管理数据.Txt,Excel,word是在数据库出现之前存储数据的. 概念:数据仓库,安装在操作系统上的软件. 数 ...

  9. 狂神说mysql笔记

    1.mysql 基本操作 Windows-->Mysql5.7打开 输入用户名和密码 查看数据库 :show databases:查询所有数据库,记住一定要加分号结尾 这里必须全部为 英文空格 ...

随机推荐

  1. 基于Docker Compose的.NET Core微服务持续发布

    是不是现在每个团队都需要上K8s才够潮流,不用K8s是不是就落伍了.今天,我就通过这篇文章来回答一下. 一.先给出我的看法和建议 我想说的是,对于很多的微小团队来说,可能都不是一定要上K8s,毕竟上K ...

  2. 使用迭代器模式批量获得数据(C#实现)

    先说一下项目的背景,以前曾经做过一个项目,根据Excel中的数据批量的到网页上抓取数据,将抓取到的数据批量的回填到Excel中.这个Excel中有很多行的记录(多的时候会有好几千行),每一行数据存储能 ...

  3. Postman之API测试使用全指南

    Postman Postman是一个可扩展的API开发和测试协同平台工具,可以快速集成到CI/CD管道中.旨在简化测试和开发中的API工作流. Postman 工具有 Chrome 扩展和独立客户端, ...

  4. 如何在Vim中更改颜色和主题

    大家好,我是良许. Vim是我们在Linux中非常常用的一款文本编辑器.Vim 是一款免费.开源的文本编辑器,它的功能和许多其他的文本编辑器大致相同,比如 Sublime 和 Notepad++ .V ...

  5. 【UVA11383】 Golden Tiger Claw 【二分图KM算法(板子)】

    题目 题目传送门:https://www.luogu.com.cn/problem/UVA11383 分析 最近刚刚学了二分图,然后来了一个这样的题,看完题意之后,稍微想一想就能想出来是一个二分图,然 ...

  6. Java多线程可重入锁例子解析

    “可重入锁”的概念是:自己可以再次获得自己的内部锁.比如有一条线程获得了某个对象的锁,此时这个对象还没有释放,当其再次想获得这个对象的锁的时候还是可以获得的,如果不可锁重入的话,就会造成死锁. cla ...

  7. 阿里云Linux CentOS8.1 64位服务器安装LNMP(Linux+Nginx+MySQL+PHP) 并发调试之调试工具ab(apache bench)

    ab 测试工具,全称是 apache bench ,是 Apache 提供的一款测试工具,具有简单易上手的特点,在测试 Web 服务时非常实用. ab 可以在 Windows 系统中使用,也可以在 L ...

  8. 用Serverless Kubernetes为.NET (Core)应用保驾护航

    前言 容器化对现在(0202年)来说,已经不算是什么新东西了,老黄最近也在公司推动这一块的发展,有幸落地了几个项目,有.NET Core的,也有.NET Framework的. 容器化现在主流的就是d ...

  9. 记一次WPF程序带参数启动

    问题:总共有两个程序.第一个程序使用Process带参数启动第二个程序. 网上一堆人都说什么重写Main入口啊 什么的.然后还一堆人跟着复制发文章.我也是醉了,简直是坑人.为何要舍近求远,直接重写AP ...

  10. HDFS客户端环境准备

    一.下载Hadoop jar包至非中文路径 下载链接:https://hadoop.apache.org/releases.html 解压至非中文路径 二.配置Hadoop环境变量 配置HADOOP_ ...