MySQL用表组织数据

news2024/12/27 2:07:51

用表组织数据

文章目录

  • 用表组织数据
    • 一.四种完整性约束
    • 二.数值类型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.coloradmin.cn/o/2266120.html

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

相关文章

iOS开发代码块-OC版

iOS开发代码块-OC版 资源分享资源使用详情Xcode自带代码块自定义代码块 资源分享 自提: 通过网盘分享的文件:CodeSnippets 2.zip 链接: https://pan.baidu.com/s/1Yh8q9PbyeNpuYpasG4IiVg?pwddn1i 提取码: dn1i Xcode中的代码片段默认放在下面的目录中…

基于微信小程序的校园访客登记系统

基于微信小程序的校园访客登记系统 功能列表 用户端功能 注册与登录 :支持用户通过手机号短信验证码注册和登录。个人资料管理 :允许用户编辑和更新个人信息及其密码。站内信消息通知:通知公告。来访预约:提交来访预约支持车牌…

mac启ssh服务用于快速文件传输

x.1 在mac上启SSH服务 方法一:图形交互界面启ssh(推荐) 通过sharing - advanced - remote login来启动ssh;(中文版mac应该是 “系统设置 → 通用 → 共享”里打开“远程登录”来启动) 查看自己的用户名和…

Magnet: 基于推送的大规模数据处理Shuffle服务

本文翻译自:《Magnet: Push-based Shuffle Service for Large-scale Data Processing》 摘要 在过去的十年中,Apache Spark 已成为大规模数据处理的流行计算引擎。与其他基于 MapReduce 计算范式的计算引擎一样,随机Shuffle操作(即…

面试真题:Integer(128)引发的思考

引言 在 Java 编程语言中,数据类型的使用至关重要。作为一种静态类型语言,Java 提供了丰富的基本数据类型和对应的包装类。其中,Integer 类是 int 类型的包装类,承载着更复杂的功能,如缓存、装箱和拆箱等。掌握 Integ…

Windows脚本清理C盘缓存

方法一:使用power文件.ps1的文件 脚本功能 清理临时文件夹: 当前用户的临时文件夹(%Temp%)。系统临时文件夹(C:\Windows\Temp)。 清理 Windows 更新缓存: 删除 Windows 更新下载缓存&#xff0…

Type-c接口

6P Type C 接口座: 仅支持充电 16P 与 12P Type C 接口座: 支持数据传输 Type-c引脚: SUB1,SUB2为辅助通讯引脚,主要用在音视频信号传输中,很多DIY都用不到 CC1、CC2引脚用于连接检测,一般可以不用连接&am…

基于python语音启动电脑应用程序

osk模型进行输入语音转换 txt字典导航程序路径 pyttsx3引擎进行语音打印输出 关键词程序路径 import os import json import queue import sounddevice as sd from vosk import Model, KaldiRecognizer import subprocess import time import pyttsx3 import threading# 初始…

互联网视频云平台EasyDSS无人机推流直播技术如何助力野生动植物保护工作?

在当今社会,随着科技的飞速发展,无人机技术已经广泛应用于各个领域,为我们的生活带来了诸多便利。而在动植物保护工作中,无人机的应用更是为这一领域注入了新的活力。EasyDSS,作为一款集视频处理、分发、存储于一体的综…

垃圾分割数据集labelme格式659张1类别

数据集格式:labelme格式(不包含mask文件,仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数):659 标注数量(json文件个数):659 标注类别数:1 标注类别名称:["garbage"] 每个类别标注的框数&#…

记我的Springboot2.6.4从集成swagger到springdoc的坎坷路~

项目背景 主要依赖及jdk信息: Springboot:2.6.4 Jdk: 1.8 最近新搭建了一套管理系统,前端部分没有公司的前端团队,自己在github上找了一个star较多使用相对也简单的框架。在这个管理系统搭建好上线之后,给组内的小伙…

NNDL 作业11 LSTM

习题6-4 推导LSTM网络中参数的梯度, 并分析其避免梯度消失的效果 先来推个实例: 看式子中间,上半部分并未有连乘项,而下半部分有到的连乘项,从这可以看出,LSTM能缓解梯度消失,梯度爆炸只是不易…

uniapp使用live-pusher实现模拟人脸识别效果

需求: 1、前端实现模拟用户人脸识别,识别成功后抓取视频流或认证的一张静态图给服务端。 2、服务端调用第三方活体认证接口,验证前端传递的人脸是否存在,把认证结果反馈给前端。 3、前端根据服务端返回的状态,显示在…

MySQL中Performance Schema库的详解(下)

昨天说了关于SQL语句相关的,今天来说说性能相关的,如果没有看过上篇请点传送门https://blog.csdn.net/2301_80479959/article/details/144693574?fromshareblogdetail&sharetypeblogdetail&sharerId144693574&sharereferPC&sharesource…

YOLO11全解析:从原理到实战,全流程体验下一代目标检测

前言 一、模型介绍 二、网络结构 1.主干网络(Backbone) 2.颈部网络(Neck) 3.头部网络(Head) 三、算法改进 1.增强的特征提取 2.优化的效率和速度 3.更高的准确性与更少的参数 4.环境适应性强 5.…

【Qt】了解和HelloWorld

目录 0.用户交互界面风格 Windows下GUI开发方案? 1.Qt简介 1.1 版本Qt5. 1.2搭建Qt开发环境 需要安装3个工具 安装过程 熟悉QtSDK重要工具 2.使用Qt Creator创建项目 2.1代码解释 2.2helloworld 1.图形化方式 2.代码方式 0.用户交互界面风格 1.TUI&…

原点安全再次入选信通院 2024 大数据“星河”案例

近日,中国信息通信研究院和中国通信标准化协会大数据技术标准推进委员会(CCSA TC601)共同组织开展的 2024 大数据“星河(Galaxy)”案例征集活动结果正式公布。由工银瑞信基金管理有限公司、北京原点数安科技有限公司联…

【MySQL初阶】--- 数据类型

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏: MySQL 🏠 数据类型分类 MySQL是一套整体的对外数据存取方案,既然要存取数据,而数据有不同的类型,因此MySQL也存在不同的数据类型,有不同的用…

使用VsCode编译调试Neo4j源码

文章目录 使用VsCode编译调试Neo4j源码1 简介2 步骤1 下载源码2 依赖3 构建Neo4j4 运行5 安装VsCode扩展6 **调试** 使用VsCode编译调试Neo4j源码 1 简介 Neo4j作为领先的图数据库,在存储、查询上都非常值得分析学习。通过调试、日志等方法跟踪代码工作流有助于理…

从零开始构建美颜SDK:直播美颜插件的开发实践指南

很多人好奇的一个问题,直播APP中主播们的美颜功能是如何实现的,今天,我们将以构建一款美颜SDK为主线,从技术架构、功能设计到开发实践,为读者提供一个全面的指导。 一、美颜SDK的核心技术 要构建一款优秀的美颜SDK&a…