【MYSQL】数据类型和约束

目录

数据类型

1.数值类型

1.1.位--类型bit(M)

1.2. 整数类型--tinyint,smallint,int,bigint

1.3.小数类型--float、decimal

2.字符类型--char、varchar

3.日期类型--datetime、timestamp

4.string类型--enum和set

 mysql的约束

1.空属性--null

2.默认值--default

3.注释--comment

4. 显示位数--zerofill

5.主键(primary key)

5.1.复合主键

5.2.自增长--auto_increment

6.唯一键--unique

7.外键--foreign key

7.1.外键约束


数据类型

1.数值类型

1.1.位--类型bit(M)

数据类型大小说明
bit(M)由M决定,0-2^M-1;M取值1-64,bit大小也就是最小0-2^1-1,最大0-2^64-1;默认为1

例子: 

1.2. 整数类型--tinyint,smallint,int,bigint

  • 就是对应C语言的char、short、int、long long
  • 都可以添加unsigned约束,就只能去正整数了,例如int范围变为0到2^32-1;
数据类型大小说明
tinyint1字节范围-2^7到2^7-1;
smallint2字节范围-2^15到2^15-1;
int4字节范围-2^31到2^31-1;
bigint8字节范围-2^63到2^63-1;
多了一行,是我写多了

1.3.小数类型--float、decimal

数据类型大小说明
float(M,D)4字节单精度,M指定长度,D指定小数位数,会发生丢失精度
double(M,D)8字节和floar相同
decimal(M,D)双精度,M指定长度,D指定小数位数,准确数组
  • float(4,2)的范围是[-99.99,99.99] ;
  • float等小数类型都遵守四舍五入的准则插入;
  • folat等也是可以使用unsigned的,不够范围会变成整数,[0,99.99];

 decimal和float的区别

  • float的精度大概有7位,decimal的精度很高;
  • 当对精度有要求的时候使用dec 

2.字符类型--char、varchar

  • 像电话号码、身份证号就是char固长;
  • 像地址、姓名就使用varchar变长;
数据类型大小说明
char最大255个字符,一个字符1-3个字节固定长度,效率更高,但是空间浪费,就像c语言char tem[12];
varcahr0-65535字节变长,效率没有固长快,但是更节省空间,就像string tem;

 

3.日期类型--datetime、timestamp

  • 时间戳会自动检测当前时间填入,在修改数据也会自动检测当前时间填入;
数据类型大小说明格式
datetime8字节范围从1000到9999年yyy-mmm-ddd hh-mm-ss
timestamp4字节范围1979到2038年,自动检索当前时 区并进行转换yyy-mmm-ddd hh-mm-ss

4.string类型--enum和set

enum和set存储的是整数,0表示为空,>0表示非空

  • enum如下面的选项’男‘ ,’女’分别代表‘1’,‘2’;依次递增,最大2^16;
  • set最多有64个选项,它是一个位图0111就代表‘写代码,唱歌,跳舞’;
数据类型说明
enum多选一,选项上限2^16个;
set多选多,选项上限64个;

 mysql的约束

  • 数据类型就是一种约束,但是比较单一需要一些其他的约束来相互配合;

1.空属性--null

  • mysql默认是null的,null表示没有填写或不存在,!=0;

 可以设置为not null表示必须填写;

2.默认值--default

  • 设置一个默认值不填就使用默认值

3.注释--comment

查看创建信息;

show create table 表名 \G

4. 显示位数--zerofill

  • 配合整形(位数),填充位数;

5.主键(primary key)

  • 主键约束不能为空且唯一,因为它是用于检索的;

5.1.复合主键

  • 多列数据做为主键;

5.2.自增长--auto_increment

  • 不插入值时,使用当前最大值+1;
  • 通常和主键连用; 

6.唯一键--unique

  • unique是可以为空的;相同不能插入

 

主键和唯一键

  • 主键和唯一键的差别就是主键不可以为null,唯一键可以;
  • 主键和唯一键是相互协作和补充的;
  • 主键是用于检索的,它不能为空所有的记录都会有唯一值;主键就像学号在学校是最主要的识别你身份的信息,但是你还有一些唯一的信息那么就是唯一键 

7.外键--foreign key

  • 使用外键只使用一个整数,更节省空间

7.1.外键约束

  • 从表插入主表没有的数据会插入失败
  • 主表删除,从表还有那么删除不了

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【人工智能】— 不确定性、先验概率/后验概率、概率密度、贝叶斯法则、朴素贝叶斯 、最大似然估计

【人工智能】— 不确定性 不确定性不确定性与理性决策基本概率符号先验概率(无条件概率)/后验概率(条件概率)随机变量概率密度联合概率分布公理完全联合分布概率演算独立性 贝叶斯法则例1例2 使用贝叶斯规则:合并证据朴素贝叶斯最大似然估计小结 不确定性 不确定性与…

PCIe物理层详细总结-PCIE专题知识(一)

目录 一、简介二、PCIe物理层结构及功能2.1 PCIe端对端连接方式2.2 PCIe组成2.2.1 逻辑层(Logic)1 发送逻辑2 接收逻辑 2.2.2 电气层(Electrical)1 物理层-电气(Physical Layer Electrical)2 数据传送----差分方式 2.2.3 PLP介绍 三、其他相关链接1、PCI总线及发展历程总结2、P…

mockjs学习笔记

文章目录 一、什么是mockjs二、安装mockj项目安装mock 三、mock语法生成字符串生成文本生成标题和句子生成段落生成数字生成自增id生成姓名-地址-身份证随机生成图片生成时间 mock拦截请求定义get请求定义post请求 四、实现新闻管理案例获取数据添加新闻删除新闻 一、什么是moc…

最优化方法Python计算:一元函数搜索算法——二分法

设一元目标函数 f ( x ) f(x) f(x)在区间 [ a 0 , b 0 ] ⊆ R [a_0,b_0]\subseteq\text{R} [a0​,b0​]⊆R(其长度记为 λ \lambda λ)上为单峰函数,且在 ( a 0 , b 0 ) (a_0,b_0) (a0​,b0​)内连续可导,即其导函数 f ′ ( x ) f…

PySpark基础入门(1):基础概念+环境搭建

目录 Spark基础入门 spark基础概念 spark架构 Spark环境搭建 local模式 Standalone 模式 Spark On YARN 模式 PySpark开发环境搭建 Python On Spark 执行原理 更好的阅读体验:PySpark基础入门(1):基础概念+环…

数字图像处理--matlab图像反转、对数变换、伽马变换、对比度拉伸详解和代码实现

灰度变换在图像的单个像素上操作,主要以对比度和阈值处理为目的 空间滤波涉及改善性能的操作(邻域操作),如通过图像中每一个像素的邻域处理来锐化图像 这两种方法均属于图像增强。 灰度变换 邻域基本增强变换定义数学表达三种基本…

基于协同过滤的旅游推荐系统设计与实现(论文+源码)_kaic

1 绪论 1.1 研究背景及意义 1.2 国内外研究现状 1.3 研究目标与意义 1.4 主要研究工作 2 相关理论介绍 2.1HTML与JavaScript 2.2 MySQL数据库 2.3 协同过滤算法简介 3 系统分析与设计 3.1 系统需求分析 3.1.1 功能性需求 3.1.2 安全性需求 3.2 系统总体架构 3.3 功能模块设计 3…

【LeetCode】221.最大正方形

221.最大正方形(中等) 题解 对于在矩阵内搜索正方形或长方形的题型,一种常见的做法是:定义一个二维 dp 数组,其中 dp[i][j] 表示满足题目条件的、以(i,j)为右下角的正方形或长方形属性。在本题中…

Android 编译模块 (小记)

1.整编 source build/envbuild.sh lunch xxx make 2.单独编译模块 2.1 去Android.bp 中找模块名 比如我想编译system/core/fastboot,那么我就去找这个路径下的Android.bp/ Android.mk Android.bp 中找每个模块的那么就行 然后直接make这个name make fastboot_…

设置苹果电脑vsode在新窗口中打开文件

0、前言 最近切换到mac电脑工作,又得重新安装一些工具软件并设置。虽然这些设置并表示啥复杂的设置,但是久了不设置还是会忘记。于是记录之,也希望给能帮助到需要的人。 我们使用vscode阅读或者编辑文件时,有时候希望同时打开多…

3个经典线程同步问题

生产者消费者问题 问题描述 系统中有一组生产者进程和一组消费者进程,生产者进程每次生产一个产品放入缓冲区,消费者进程每次从缓冲区中取出一个产品并使用。生产者、消费者共享一个初始为空、大小为n的缓冲区 伪码描述 semaphore mutex 1;//互斥信…

SpringBoot集成 ElasticSearch

Spring Boot 集成 ElasticSearch 对于ElasticSearch比较陌生的小伙伴可以先看看ElasticSearch的概述ElasticSearch安装、启动、操作及概念简介 好的开始啦~ 1、基础操作 1.1、导入依赖 <dependency><groupId>org.springframework.boot</groupId><arti…

2023 年 五一杯 B 题过程 + 代码(第一问)

文章目录 第一题问题分析PageRank 算法&#xff08;可跳过&#xff09;PageRank 算法修正权重系数 结果各城市链出与链入链出 权重链入 权重 PageRank 算法结果代码 第一题 问题分析 从收货量、发货量、快递数量增长/减少趋势、相关性等多角度考虑&#xff0c;建立数学模型&…

基于jQuery------购物车案例

目录 基于jQuery------购物车案例 案例&#xff1a;购物车案例模块-增减商品数量分析 案例&#xff1a;购物车案例模块-修改商品小计分析 案例&#xff1a;购物车案例模块-计算总计和总额 案例&#xff1a;购物车案例模块-删除商品模块 案例&#xff1a;购物车案例模块-选…

基于.Net开发的、支持多平台、多语言餐厅点餐系统

今天给大家推荐一套支持多平台、多语言版本的订单系统&#xff0c;适合餐厅、酒店等场景。 项目简介 这是基于.Net Framework开发的&#xff0c;支持手机、平板、PC等平台、多语言版本开源的点餐系统&#xff0c;非常适合餐厅、便利店、超市、酒店等&#xff0c;该系统基础功…

C语言宏使用

C语言宏 编译一个C语言程序的第一步骤就是预处理阶段&#xff0c;这一阶段就是宏发挥作用的阶段,编译完之后宏对二进制代码不可见。 使用 1. 宏常量 #define PI 3.142. 宏语句 #define Print printf("hello,world!\r\n")3. 宏函数 使用宏来定义函数&#xff0c…

UDP的报文结构和注意事项

1.UDP的报文结构 UDP的报文结构如图&#xff1a; 画成一行会比较好理解&#xff1a; 主要由两部分组成&#xff1a;UDP报头和UDP载荷。 UDP载荷其实就是数据。 UDP报头分为四个部分&#xff0c;每个部分占两个字节。 源端口目的端口报文长度校验和 下面介绍报头里各个部分…

论文阅读《PIDNet: A Real-time Semantic Segmentation Network Inspired by PID》

论文地址&#xff1a;https://arxiv.org/pdf/2206.02066.pdf 源码地址&#xff1a;https://github.com/XuJiacong/PIDNet 概述 针对双分支模型在语义分割任务上直接融合高分辨率的细节信息与低频的上下文信息过程中细节特征会被上下文信息掩盖的问题&#xff0c;提出了一种新的…

【操作系统复习】第5章 存储器管理 2

分页存储管理方式 页号P ◆12-31位&#xff1a;20位 ◆地址空间最多允许有1M&#xff08;2 20&#xff09;页 位移量W&#xff08;页内地址&#xff09; ◆0-11&#xff1a;12位 ◆每页大小为4KB &#xff08;2 12&#xff09; 对某特定机器&#xff0c;地址结构是一…

Apache Flink (最新版本) 远程代码执行

路虽远&#xff0c;行则将至&#xff1b;事虽难&#xff0c;做则必成 Apache Flink < 1.9.1(最新版本) 远程代码执行 CVE-2020-17518 漏洞描述 近日,有安全研究员公开了一个Apache Flink的任意Jar包上传导致远程代码执行的漏洞. 漏洞影响 Apache Flink < 1.9.1(最新…