MySQL增删查改(进阶1)

一、数据库约束

约束:按照一定条件进行规范的做事;

表定义的时候,某些字段保存的数据需要按照一定的约束条件;

1.null约束

  • 字段null:该字段可以为空;not null:该字段不能为空
  • 不指定的话就是null

id int not null;

2.unique:唯一约束

表示某个字段,不能重复(实际可以使用多个字段来建立unique唯一约束)

null不进行unique唯一校验;

sn int unique;

当sn重复时便会报错

3.default:默认值约束

表示某个字段设置了default及默认值,插入的时候该列不插入,就会插入默认值。

显示的插入数据即使是null,默认值也不会生效

name varchar(20) default 'unkown';

插入的字段不使用name,才会插入默认值:

4.primary key:主键约束

主键一般用于某张表标识唯一的一条数据

  • primary key =not null unique

仅仅unique约束的字段,还可以保存多条null的数据,也不能标识唯一的数据

主键字段不插入或者插入重复的都会报错

 一张表一般都需要设计主键

如果使用整型主键还可以结合auto_increment,表示从1开始,++自增

 自增不是以最大值加1的方式,而是mysql记录了这个值来递增。

 再插入数据,id就可能不连续

5.foreign key:外键约束

用于设计表与表之间的关系

表1(主表:主键)-----表2(从表:外键):就可以建立表1和表2一对一或者一对多的关系

二、表的设计

数据库设计表关系

主表的主键关联从表的外键(建立外键,不一定非要使用主键来关联,只是常用主键和外键关联)

create table 主表(

  id int primary key auto_increment,

...

);

create table 从表(

  id int primary key auto_increment,

...

  主表_id int,

   foreign key (主表_id) references 主表(id)

);

上面两个表中 蓝色部分建立关系

foreign key (主表_id) references 主表id)--->

主表_id:从表的外键字段名

主表:主表的表名;

id:主表的关联字段名(一般使用主键)

1.一对一的关系

比如:人对身份证

id:主键

name:姓名

amount:存款

username:账号

password:密码

身份证

id:主键

身份证号:*******

住址:*******

......

user_id:外键

建立人的主键与身份证外键的联系

从现实看,其实可以设计成一张表,但是人这张表查询比较频繁,如果把身份证相关的字段也放在一起,那么比较频繁的又不获取身份证信息的查询效率就比较低。

设计为一对一关系的两张表目的是:

  1. 数据库表设计其实就是建模(建立一种对象模型)
  2. 解耦:模型之间的解耦
  3. 效率:不经常使用的数据,单独存储,效率会比较高

2.一对多的关系

班级表

班级id

班级名称

...

学生表

学生 id:主键

学生姓名

学号

班级id:外键

班级id就是班级表和学生表之间的关联

一对多其实是有方向的,包含:

(1)班级到学生:一对多,一个班级多个学生

(2)学生到班级,一对一,一个学生一个班级

3.多对多的关系

表设计的时候(这个多对多关系,在两张主表中没有外键体现):

(1)两张主表建立多对多关系

(2)使用一张单独的中间表来表示两张主表的多对多关系

学生和课程再某个业务发生后就可能产生关系:

考试:一个学生考多门课程,一门课程有多个学生考试

设计上使用中间表:

(1)两个外键:分别关联两张主表的主键

(2)还可能设计一些业务的字段,比如考试成绩

学生表和课程表是多对多的关系(逻辑上的多对多关系),主表没有关系的体系;

中间表(体现实际的多对多关系),两个外键其实就表现出多对多的关系;

插入数据:

 在MySQL中执行后:

 表结构上只有两个一对多关系;数据上,体现出两个一对多关系,及逻辑上的多对多关系;

  • 一个学生考多个试--->学生表:中间表=1:n
  • 一个课程有多个考试成绩--->课程表:中间表=1:m
  • 中间表(考试成绩表)--->学生:课程=n:m

三、新增

插入操作:insert into 表 select...from 表 where... order by ... limit;

使用场景:

(1)复制表

(2)提前准备一些统计的数据(统计的sql一般关联很多表,条件可能也很复杂,执行效率可能不高),很多系统就提前运行任务,将统计的数据准备在单独的一张表中

 把查询结果集返回的所有数据,按查询出来的字段顺序,插入到insert表给的字段。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/97796.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

优优嗨聚集团:OTC药品能否纳入报销成为各方关注焦点,对OTC医疗有何影响

随着医疗费用的不断上涨,各方对于非处方药(OTC)能否纳入报销的关注度也在不断提升。OTC药品是指无需医生处方即可购买的药品,具有方便快捷、安全有效的特点。然而,对于是否将OTC药品纳入报销范围,各方看法不…

NewStarCTF 2023 WEEK1|PWN ret2text

拖进IDA,查看 int __cdecl main(int argc, const char **argv, const char **envp) {char buf[32]; // [rsp0h] [rbp-20h] BYREFinit();puts("Welcome to NewStar CTF!!");puts("Show me your magic");read(0, buf, 0x100uLL);return 0; } ma…

Java版本+企业电子招投标系统源代码之电子招投标系统建设的重点和未来趋势

一、立项管理 1、招标立项申请 功能点:招标类项目立项申请入口,用户可以保存为草稿,提交。 2、非招标立项申请 功能点:非招标立项申请入口、用户可以保存为草稿、提交。 3、采购立项列表 功能点:对草稿进行编辑&#x…

46 二叉树展开为链表

二叉树展开为链表 理解题意:前序遍历的N种写法题解1 前序遍历题解2 反前序遍历(代码简洁)题解3 类似旋转的方法题解4 迭代题解5 同时遍历改左右子树 给你二叉树的根结点 root ,请你将它展开为一个单链表: 展开后的单链表应该同样使用 TreeNo…

Day-05 CentOS7.5 安装 Docker

参考 : Install Docker Engine on CentOS | Docker DocsLearn how to install Docker Engine on CentOS. These instructions cover the different installation methods, how to uninstall, and next steps.https://docs.docker.com/engine/install/centos/ Doc…

让照片人物开口说话,SadTalker 安装及使用(避坑指南)

AI技术突飞猛进,不断的改变着人们的工作和生活。数字人直播作为新兴形式,必将成为未来趋势,具有巨大的、广阔的、惊人的市场前景。它将不断融合创新技术和跨界合作,提供更具个性化和多样化的互动体验,成为未来的一种趋…

[C++基础]-多态

前言 作者:小蜗牛向前冲 名言:我可以接受失败,但我不能接受放弃 如果觉的博主的文章还不错的话,还请点赞,收藏,关注👀支持博主。如果发现有问题的地方欢迎❀大家在评论区指正。 本期学习目标&am…

数据库配置mysql5.7

1 创建数据库 """ 1.管理员连接数据库 mysql -uroot -proot2.创建数据库 create database hello default charsetutf8;3.查看用户 select user,host,password from mysql.user;# 5.7往后的版本 select user,host,authentication_string from mysql.user; "…

力扣-345.反转字符串中的元音字母

Idea 将s中的元音字母存在字符串sv中,并且使用一个数组依次存储元音字母的下标。 然后将字符串sv进行反转,并遍历元音下标数组,将反转后的字符串sv依次插入到源字符串s中 AC Code class Solution { public:string reverseVowels(string s) {…

【进阶C语言】数组笔试题解析

本节内容以刷题为主,大致目录: 1.一维数组 2.字符数组 3.二维数组 学完后,你将对数组有了更全面的认识 在刷关于数组的题目前,我们先认识一下数组名: 数组名的意义:表示数组首元素的地址 但是有两个例外…

强化学习环境 - robogym - 学习 - 3

强化学习环境 - robogym - 学习 - 3 文章目录 强化学习环境 - robogym - 学习 - 3项目地址为什么选择 robogymObservation - 观测信息Action - 动作信息Initialization - 初始状态设置 项目地址 https://github.com/openai/robogym 为什么选择 robogym 自己的项目需要做一些机…

微信小程序使用路由传参和传对象的方法

近期在做微信小程序开发,在页面跳转时,需要携带参数到下一个页面,尤其是将对象传入页面。为了方便重温,特此记录。 路由传字符串参数 原始页面 传递字符串参数比较简单。路由跳转有两种方式,一种是通过navigator组件…

企业AI工程化之路:如何实现高效、低成本、高质量的落地?

MLOps工程实践 概述面临挑战目的内容简介读者对象专家推荐目录 写在末尾: 主页传送门:📀 传送 概述 作为计算机科学的一个重要领域,机器学习也是目前人工智能领域非常活跃的分支之一。机器学习通过分析海量数据、总结规律&#x…

Flask实现注册登录模块

🙌秋名山码民的主页 😂oi退役选手,Java、大数据、单片机、IoT均有所涉猎,热爱技术,技术无罪 🎉欢迎关注🔎点赞👍收藏⭐️留言📝 获取源码,添加WX 目录 前言1.…

机器学习之SGD, Batch, and Mini Batch的简单介绍

文章目录 总述SGD(Stochastic Gradient Descent)(随机梯度下降)Batch (批量)mini Batch (迷你批量) 总述 SGD, Batch, and Mini Batch是可用于神经网络的监督学习计算权重更新的方案,即∆wij。 SGD(Stochastic Gradi…

el-tree中插入图标并且带提示信息

<template><div class"left"><!-- default-expanded-keys 默认展开 --><!-- expand-on-click-node 只有点击箭头才会展开树 --><el-tree :data"list" :props"defaultProps" node-click"handleNodeClick" :…

c语言进阶部分详解(详细解析字符串常用函数,并进行模拟实现(下))

上篇文章介绍了一些常用的字符串函数&#xff0c;大家可以跳转过去浏览一下&#xff1a;c语言进阶部分详解&#xff08;详细解析字符串常用函数&#xff0c;并进行模拟实现&#xff08;上&#xff09;&#xff09;_总之就是非常唔姆的博客-CSDN博客 今天接着来介绍一些&#x…

Linux防火墙之--SNAT和DNAT

1.SNAT是什么 SNAT又称源地址转换。源地址转换是内网地址向外访问时&#xff0c;发起访问的内网ip地址转换为指定的ip地址&#xff08;可指定具体的服务以及相应的端口或端口范围&#xff09;&#xff0c;这可以使内网中使用保留ip地址的主机访问外部网络&#xff0c;即内网的多…

腾讯云轻量和CVM有啥区别?怎么选择服务器配置?

腾讯云轻量服务器和云服务器有什么区别&#xff1f;为什么轻量应用服务器价格便宜&#xff1f;是因为轻量服务器CPU内存性能比云服务器CVM性能差吗&#xff1f;轻量应用服务器适合中小企业或个人开发者搭建企业官网、博客论坛、微信小程序或开发测试环境&#xff0c;云服务器CV…

TDengine OSS 与 qStudio 实现无缝协同,革新数据分析和管理方式

在数字化转型如火如荼的当下&#xff0c;海量爆发的时序数据处理成为转型成功的关键因素之一。为了帮助社区用户更好地进行数据分析和管理&#xff0c;丰富可视化解决方案的多样性&#xff0c;我们将开源的时序数据库&#xff08;Time Series Database&#xff09; TDengine OS…