MySQL用表组织数据

用表组织数据

文章目录

  • 用表组织数据
    • 一.四种完整性约束
    • 二.数值类型2-1
    • 三.数值类型2-2
    • 四.字符串.日期类型
    • 五.设置
        • 1.设置主键
        • 2.设置标识列
        • 3.设置非空
        • 4.设置默认值
    • 六.主外键建立后注意事项

一.四种完整性约束

1.域完整性 列

域完整性约束方法:限制数据类型,检查约束,外键约束,默认值,非空约束

2.实体完整性 行

实体完整性约束方法:唯一约束,主键约束,标识列

三个都在干一件事:让某些值唯一的不重复

主键约束里面就包含了唯一约束

主键要求不重复 并且不能为空

3.引用完整性 表与表之间

引用完整性约束方法:外键约束

4.自定义完整性 自己定义

自定义完整性约束方法:规则,存储过程,触发器

触发器:检查信用值

二.数值类型2-1

intyint 非常小的数据

smallint 较小的数据

mediumint 中等大小的数据

int 标准整数

bigint 较大的整数

float 单精度浮点数

bouble 双精度浮点数

单精度和双精度最大的区别:范围不一样 双精度更大

decimal 字符串形式的浮点数

三.数值类型2-2

unsigned属性

标识为无符号数

如果不设置:默认是有符号的

无符号影响的是负数

zerofill属性

宽度(位数)不足以0填充

在这里插入图片描述

此时是5个长 总长是5 值不足5时 用0填充

在这里插入图片描述

若某数值字段指定了zerofill属性,将自动添加unsigned属性

在这里插入图片描述

四.字符串.日期类型

char[(m)] 定长字符串

char和zerofill很像 设置长度是5 值是a 会在a后面补4个空格 也限定了字符串的长度 就是设置的长度

varchar[(m)] 可变字符串
设置长度是5 如果你输入的值是b 那他就是b 不补 因为是可变字符串

tinytext 微型文本串

text 文本串

放手机号 放邮箱 放家庭地址

date YYYY-MM-DD 年–月–日 日期格式

不需要精确到时分秒 可以用date 比如生日 但重复率高

datetime YY-MM-DD hh:mm:ss: 年–月–日–时–分–秒

精确到 年–月–日–时–分–秒 可以用 datetime

time hh:mm:ss: 时–分–秒

timestamp YYYYMMDDHHMMSS

tear YYYY格式的年份 年

若某日期字段默认值为当前日期,一般设置为timestamp类型

default:设置默认值

五.设置

1.设置主键

一个表可以没有主键

有主键的话 只能有一个主键 这一个主键可以由多个列组成

有多个列组成的主键 叫做复合主键

最少性:尽量选择单个键作为主键

稳定性:尽量选择数值更新少的列作为主键

2.设置标识列

auto incr:自增长 自动会勾上not null

标识列的特点:必须是int 系统自动管理

即便是删掉了 系统也不会重复 继续往后算

不一定是主键 通常把它当主键使用

3.设置非空

not null 不勾就是可空 勾了就是不能为空

不勾 否

4.设置默认值

default 如果勾上not null 不写东西默认填上current_tlmestamp

可空的话就是空 什么都不填

六.主外键建立后注意事项

当主表中没有对应的记录时,不能将记录添加到子表

成绩表中不能出现在学员信息表中不存在的学号

不能更改主表中的值而导致子表中的记录孤立

把学员信息表中的学号改变了,学员成绩表中的学号也应当随之改变

子表存在与主表对应的记录,不能从主表中删除该行

不能把有成绩的学员删除了

删除主表前,先删子表

记录时,不能将记录添加到子表

成绩表中不能出现在学员信息表中不存在的学号

不能更改主表中的值而导致子表中的记录孤立

把学员信息表中的学号改变了,学员成绩表中的学号也应当随之改变

子表存在与主表对应的记录,不能从主表中删除该行

不能把有成绩的学员删除了

删除主表前,先删子表

先删学员成绩表、后删除学员信息表

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

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

相关文章

面试经典问题 —— 最大/小前K个数问题(top - K)问题

目录 常见思路更优的解法(面试官喜欢的) 常见思路 要选出最小的前K个数首先我们会想到排排升序建大堆,排降序建小堆 一个直观的想法是使用(小根堆),起始将所有元素放入堆中,然后再从堆中取出k 个…

外包干了27天,技术退步明显。。。。。

时光荏苒,转眼我已是一个拥有近四年功能测试经验的大专生。20年,我满怀激情地通过校招进入湖南某知名软件公司,期待在这里开启我的职业生涯。然而,长时间的舒适环境让我渐渐失去了前进的动力,技术停滞不前,…

从自动驾驶到具身智能漫谈

0. 简介 从作者的眼光来看自动驾驶和具身智能已经是越来越接近了。无论是技术栈以及实现的最终目的。其实都是希望人在环内。这个是古月直播的文字相关的大致梳理。主要会展开聊一聊自动驾驶的变迁以及作为自动驾驶的从业人员要着重关注的一些技术点 1. 自动驾驶的变迁 在自…

Excel粘贴复制不完整的原因以及解决方法

在数据处理和分析的过程中,Excel无疑是不可或缺的工具。然而,在使用Excel进行复制粘贴操作时,有时会遇到粘贴不完整的情况,这可能会让人感到困惑和烦恼。本文将深入探讨Excel粘贴复制不完整的原因、提供解决方案,并给出…

云原生之docker详解

目录 1.云原生概念 1.1 云原生定义 1.2 云原生元素 1.2.1 微服务 1.2.2 DevOps 1.2.3 持续交付 1.2.4 容器化 2. Docker 2.1 Docker概述 2.1.1 Docker 定义 2.1.2 Docker应用场景 2.1.3 Docker的架构 2.2 Docker命令 2.2.1 docker进程相关命令 2.2.2 docker镜像…

数仓开发那些事(8)

程序员圣经 为什么刚刚能运行,现在就不行 为什么刚刚不运行,现在就可以 为什么他的可以跑,我的不能跑 为什么我的可以跑,他的就不行 为什么这台电脑能,那台就不行 为什么这台电脑不行,那台就行 神州员工&a…

在UE5中调用ImGui图形界面库

ImGui是一个小巧灵活、简洁美观的图形界面库 首先我们直接参考Github https://github.com/SLSNe/Unreal5-ImGui 把项目下载下来后 打开项目目录或者引擎目录 项目根目录/Plugins/ImGui/ 或 UE5引擎根目录/Engine/Plugins/ 如果没有Plugins文件夹就新建一个 把项目放里面…

华为管理变革之道:奋斗文化与活力

目录 企业文化是什么? 为什么活下去是华为的文化? 活下来,是华为公司的最低纲领,也是华为公司的最高纲领! 资源终会枯竭,唯有文化才能生生不息 企业文化之一:以客户为中心 企业文化之二&a…

JZ31 栈的压入、弹出序列

题目来源:栈的压入、弹出序列_牛客题霸_牛客网 题目:如下 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序&#xf…

(echarts)数据地图散点类型根据条件设置不同的标记图片

(echarts)数据地图散点类型根据条件设置不同的标记图片 1.用在线工具将本地图片转化base64格式 data(){return { base64Img:"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQ...",} }在线转换地址:https://www.jyshare.com/front-end/59/ 2.symbol属…

ArcGIS+MIKE21 洪水淹没分析、溃坝分析,洪水淹没动态效果

洪水淹没分析过程: 一、所需数据: 1.分析区域DEM数据 二、ArcGIS软件 1.提取分析区域DEM(水库坝下区域) 2.DEM栅格转点 3.计算转换后几何点的x和y坐标值(精度20、小数位3) 4.导出属性表,形式…

LSTM-SVM时序预测 | Matlab基于LSTM-SVM基于长短期记忆神经网络-支持向量机时间序列预测

LSTM-SVM时序预测 | Matlab基于LSTM-SVM基于长短期记忆神经网络-支持向量机时间序列预测 目录 LSTM-SVM时序预测 | Matlab基于LSTM-SVM基于长短期记忆神经网络-支持向量机时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.LSTM-SVM时序预测 | Matlab基于LSTM…

虚拟机桥接模式网络连接不上解决方法

可能是桥接模式自动配置网络地址的时候没配好,自己手动配置一下。先看看windows里的wifi的ip 把虚拟机的网络设置打开ipv4把地址、子网掩码、网关输进去,然后再连接

家用无线路由器的 2.4GHz 和 5GHz

家中的无线路由器 WiFi 名称有两个,一个后面带有 “5G” 的标记,这让人产生疑问:“连接带‘5G’的 WiFi 是不是速度更快?” 实际上,这里的 “5G” 并不是移动通信中的 5G 网络,而是指路由器的工作频率为 5G…

面试场景题系列:设计一致性哈希系统

为了实现横向扩展,在服务器之间高效和均匀地分配请求/数据是很重要的。一致性哈希是为了达成这个目标而被广泛使用的技术。首先,我们看一下什么是重新哈希问题。 1 重新哈希的问题 如果你有n个缓存服务器,常见的平衡负载的方法是使用如下哈希…

【视觉惯性SLAM:相机成像模型】

相机成像模型介绍 相机成像模型是计算机视觉和图像处理中的核心内容,它描述了真实三维世界如何通过相机映射到二维图像平面。相机成像模型通常包括针孔相机的基本成像原理、数学模型,以及在实际应用中如何处理相机的各种畸变现象。 一、针孔相机成像原…

物联网网络中的设备认证方法

论文标题:DEVICE AUTHENTICATION METHOD IN INTERNET OF THINGS NETWORKS(物联网网络中的设备认证方法) 作者信息: A.Ya. Davletova,West Ukrainian National University, 11, Lvivska Str. Ternopil, 46009, Ukraine…

GitLab部署到阿里云服务器上

GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务。可通过Web界面进行访问公开的或者私人项目。它拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释。 一、安装 1.创建一…

Linux------进程处理(system库函数)

视频&#xff1a; 【尚硅谷嵌入式Linux应用层开发&#xff0c;linux网络编程&#xff0c;linux进程线程&#xff0c;linux文件io】https://www.bilibili.com/video/BV1DJ4m1M77z?p34&vd_source342079de7c07f82982956aad8662b467 #include <stdlib.h> #include <…

JAVA HTTP压缩数据

/*** 压缩数据包** param code* param data* param resp* throws IOException*/protected void writeZipResult(int code, Object data, HttpServletResponse resp) throws IOException {resp.setHeader("Content-Encoding", "gzip");// write到客户端resp…