MySQL数据库 - 基本数据类型

news2025/1/11 4:19:54


目录

一、数据类型分类

二、数据类型

1、tinyint 类型

有符号 tinyint 范围测试

 无符号 tinyint 范围测试

2、bit 类型

3、float 类型

有符号 float 范围测试 

 无符号 float 范围测试

 4、decimal 类型

 5、char 类型

6、varchar 类型

7、日期类型

8、enum类型、set类型

enum和set查找


一、数据类型分类


二、数据类型

1、tinyint 类型

有符号 tinyint 范围测试

创建一个包含 tinyint 数据类型的表结构,默认 tinyint 是有符号的:

 因为 tinyint 类型占用 1 字节,所以取值范围为 -128 ~ 127,插入的数据在该范围内,就可以成功插入进入:

如果插入的数据范围,超过了 -128~127,那么插入就会报错:


 无符号 tinyint 范围测试

创建一个包含 tinyint 类型的表结构,并指定其为无符号类型:

因为 tinyint 类型占用 1 字节的存储空间,因此无符号 tinyint 的取值范围为 0~255,插入的数据在这个范围内都可以成功插入:

 如果插入的数据不在 0~255 之间,那么插入的数据时就会报错误:

 注意:

        尽量不要使用 unsigned,对于 tinyint 类型可能存放不下的数据,tinyint unsigned 同样可能存储不下,还不如设计的时候,将数据类型进行提升。


2、bit 类型

基本语法:

bit [(M)]:位字段类型。M表示每个值的位数,范围 1~ 64,如果 M 被忽略,默认为 1。

创建一个包含 int 类型,以及 8 位bit类型的表结构:

向表中插入,a 值为 10,11两条记录,发现 a 字段显示的并不是 10,11:

 

 因为 bit 类型在显示时,对应是按照 ASCII码值进行显示的,其中 10 对应的控制字符为 LF,表示换行符号,11 对应的控制字符串为 VT,表示垂直制表符。如果向表中插入,bit 值为 97,其中对应ASCII表为 字符 a,就可以显示出来了:

 如果我们有这样的值,只存放0或者1,这时可以定义 bit (1),这样可以节省空间。

此时插入2时,就已经越界了!


3、float 类型

 基本语法:

float[(m,d)] [unsigned]:M指定显示长度,d指定小数位数,占用空间4个字节。

有符号 float 范围测试 

创建一个包含 float (4,2) 类型,默认其是有符号的表结构:

 因为float (4,2) 的取值范围为 -99.99 ~ 99.99,因此插入的数据范围在这个范围内都可以成功插入:

 此外,MySQL在保存值时,会采用四舍五入的原则存储数据,实际 float (4,2) 的范围为 -99.994 - -99.994,如果插入的数据的范围超过这个范围,插入的数据记录就会报错:


 无符号 float 范围测试

创建一个 包含 float (4,2)类型,并指定为无符号的表结构:

 无符号的 float 类型取消了负数部分,因此 float (4,2) 的取值范围为 0~99.99,实际可插入的范围为 0~99.994,如果插入的记录超过这个范围就会报错:


 4、decimal 类型

decimal类型与 float类型存储的数据类型一致,都是小数类型,但是decimal存储的精度要远远高于float类型。

创建一个包含 float (10,8) 和 decimal (10,8) 类型的表结构:

向表中插入一条记录,指定 num1 与 num2 两列都是 12.12345612,最终发现decimal 保持了数据原有的形态,而 float 类型造成了一定量的精度丢失:

说明:float表示的精度大约是 7 位。

        • decimal 整数的最大位数m为65,支持小数的最大位数d为30,如果d被省略,默认为0,如果m被省略,默认为10。

建议:如果 希望小数的精度更高,推荐使用decimal。


 5、char 类型

创建一个包含 char (6) 类型的表结构:

因为 char (6) 最多可以存储 6 个字符,不是字节,因此只要插入的字符个数不超过 6 个就可以插入成功,如果字符数量超过了6个就会报错:

 注意:

       • 这里的字符,不是指一个英文字母,一个汉字也表示一个字符。

       • 不同编码中,一个字符所占的字节数量是不同的,比如:utf-8 中一个字符所占用 3 个字节,gbk中一个字符所占用2个字节。


6、varchar 类型

创建一个包含 varchar (6) 类型的表结构:

 因为 varchar(6)最多可以存储6个字符,因此只要插入的数据在6个字符范围之内,都可以被插入成功,如果超过了 6 个字符就会报错,这里是跟 char 类型是一致的:

varchar 类型最多可以占用 65535字节,其中有1 ~3 字节用来记录数据大小,因此varchar类型的有效存储字节数为 65532 字节。

而 varchar 类型可指定的字符个数的上限,与表的编码有关:

• 对于 utf-8 来说,一个字符占用 3 个字节,因此 varchar (L)中最大可指定为 65532 / 3 = 21844,如果超过这个长度就会报错:

 • 对于 gbk 来说,一个字符占用 2 个字节,因此 varchar (L)中最大可指定为 65532 / 2 = 32766,如果超过这个长度就会报错:

 char 类型 与 varchar 类型的区别:

• char 类型可存储的上限为 255,varchar 类型可存储的上限与表的编码格式有关。

• char(L) 定义后,无论存储的字符串长度是否到达L,都会开辟用于存储L个字符的定长空间,如果存储的字符串长度超过L就会报错。

• varchar(L) 定义后,会根据存储字符串的长度需要开辟空间,并且需要使用1 ~ 3 字节的空间用于表示存储字符串的长度以及其他控制信息,如果存储的字符串长度超过L就会报错。

 

char类型和varchar类型的优缺点:

• char类型的数据是定长的,因此磁盘空间比较浪费,但是效率高。

• varchar类型的数据类型是变长的,因此磁盘空间比较节省,但是效率低(需要先读取存储字符串的长度,再访问指定长度的空间)。


7、日期类型

常见的三种时间日期类型:

• date:日期格式为 yyyy-mm-dd,占用三字节

• datetime:时间日期格式为 yyyy-mm-dd hh:mm:ss 占用8个字节

• timestamp:时间戳,格式为 yyyy-mm-dd hh:mm:ss 占用4个字节

创建一个包含,date类型,datetime类型,timestamp类型的表结构:

 查看表结构可得,timestamp类型的数据是不允许为 NULL的:

因此插入数据时,不对 timestamp 列插入,它会自动更新成为时间戳:


8、enum类型、set类型

enum和set类型区别:

• 在定义enum字段时需要提供若干个选项的值,在设置enum字段值时,只允许选取其中的一个值(比如:性别的选取)。

• 在定义set字段时,需要提供若干个选项的值,在设置set字段值时,可以选取其中的一个或者多个值(比如:兴趣爱好的选取)。

创建一个包含 enum 类型和 set 类型的表结构:

以数字设置enum值:

以数字设置set值 (set的值实际是以bit位的方式进行存储的,插入时只需要将对应bit位置1即可):


enum和set查找

想在表中筛选出所有女性的信息,只需要使用 where 语句,进行判断即可:

如果要筛选出,hobby中篮球爱好者,使用上述方法是筛选不出来的:

 此时我们需要使用 find_in_set 函数:

find_in_set (sub,str_list):如果sub 在str_list中,则返回下标;如果不在,返回0,str_list用逗号分割的字符串。

如果还要增加爱好中有敲代码者,只需要后面追加 and 条件即可:


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

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

相关文章

Codeforces Round 739 (Div. 3)

A.Dislike of Threes AC代码&#xff1a; #include<iostream> #include<algorithm> #include<cstring> using namespace std; const int N2e510; int f[N]; int cnt; int main() {for(int i1;;i){if(i%3!0&&i%10!3) f[cnt]i;if(cnt>1000) break…

第一阶段-第六章 Python的数据容器

目录 一、数据容器入门  1.学习目标  2.为什么要学习数据容器  3.什么是数据容器  4.本小节的总结 二、数据容器&#xff1a;list&#xff08;列表&#xff09;  2.1列表的定义  1.学习目标  2.为什么需要列表  3.列表的定义  4.本节的代码演示  5.本小节的…

【Java练习题汇总】《第一行代码JAVA》面向对象基础篇,汇总Java练习题——面向对象:特性、类与对象、数组、String、内部类... ~

Java练习题 面向对象基础篇 1️⃣ 面向对象基础篇 1️⃣ 面向对象基础篇 一、填空题 面向对象的三大特征&#xff1a;_______ 、_______ 、_______。类由_______和_______组成。运算符_______的作用是根据对象的类型分配内存空间。当对象拥有内存空间时&#xff0c;会自动调…

oceanbase基础

与mysql对比 分布式一致性算法 paxos 存储结构&#xff08;引擎&#xff09;用的是两级的 数据库自动分片功能&#xff0c;提供独立的obproxy路由写入查询等操作到对应的分片 多租户 方便扩展 存储层 http://www.hzhcontrols.com/new-1391864.html LSM tree&#xff0c;is very…

CnOCR 使用教程

目录 一、 简介二、使用教程三、效果展示 一、 简介 CnOCR 是 Python 3 下的文字识别&#xff08;Optical Character Recognition&#xff0c;简称OCR&#xff09;工具包&#xff0c;支持简体中文、繁体中文&#xff08;部分模型&#xff09;、英文和数字的常见字符识别&#…

[COCI2010-2011#6]STEP

目录 1.题目&#xff1a; 题目描述 输入格式 输出格式 2.思路 1.ans数组的维护 2.L and R 的维护 3.ne数组与pr数组的维护 4.len数组&#xff1a; 3.代码&#xff1a; 1.有注释版&#xff1a; 2.copy版&#xff1a; 1.题目&#xff1a; 题目描述 给定一个长度为N的…

Java设计模式-责任链(Chain of Responsibility)模式

介绍 Java责任链&#xff08;Chain of Responsibility&#xff09;设计模式是指很多处理对象构成一个链&#xff0c;链中前一个对象指向后一个对象。请求在链中传递&#xff0c;一个请求可以被一个或者多个对象处理。调用方&#xff08;即客户端&#xff09;不知道请求会被链中…

【UniApp开发小程序】项目创建+整合UI组件(FirstUI和uView)

创建项目 下图为初始化的项目的文件结构 引入组件 俗话说&#xff1a;“工欲善其事&#xff0c;必先利其器”&#xff0c;为了更加方便地开发出页面较为美观的小程序&#xff0c;我们先引入成熟的UI组件&#xff0c;再开始开发之旅。&#xff08;如果你是前端高手&#xff0…

ardupilot IMU陀螺仪方向的重要性

目录 文章目录 目录摘要1.简介---BMI088 方向2.控制摘要 本节主要记录IMU陀螺仪方向的重要性,欢迎批评指正!!! 1.简介—BMI088 方向 注意这个BMI088 的IMU方向,特别是是那个左上角的黑色点点,他的坐标系满足右手坐标系,但是我们无人机坐标系是北东地坐标系,因此需要把…

Cobalt Strike实战实例

客户端 初始化界面如下&#xff1a; 可以多个客户端同时连接&#xff0c;可以聊天。 msg 指定id 文字。 msg 文字。 创建监听器 这里出现了&#xff0c;监听设置不成功。原因是服务端的CS4.0报错了。我重新下载就可以了。如果这里有问题&#xff0c;可联系我。我帮你。这里解…

python+requests接口自动化测试

原来的web页面功能测试转变成接口测试&#xff0c;之前大多都是手工进行&#xff0c;利用postman和jmeter进行的接口测试&#xff0c;后来&#xff0c;组内有人讲原先web自动化的测试框架移驾成接口的自动化框架&#xff0c;使用的是java语言&#xff0c;但对于一个学java&…

Feign远程调用组件

Feign Feign是Netfix开发的一个轻量级REstFul的HTTP服务客户端,是以java接口注解的方式调用HTTP请求,而不用像java中通过封装HTTP请求报文的方式直接调用,可以帮助我们更加便捷,优雅的调用HTTP API Feign RestTemplate Ribbon Hystrix 本质:封装了HTTP调用流…

JAVA (static) 简述

前言&#xff1a; 在力扣上提交代码&#xff0c;发现用static定义变量&#xff0c;和不用static修饰变量&#xff0c;虽然每次运行的结果都一样&#xff0c;但是提交的结果却有通过与不通过两种情况。 测试题目&#xff1a;组合&#xff08;力扣&#xff09;dfs 回溯 剪枝 JA…

Redis数据结构 — List

目录 链表结构设计 ​编辑链表节点结构设计 链表的优势与缺陷 Redis 的 List 对象的底层实现之一就是链表。C 语言本身没有链表这个数据结构的&#xff0c;所以 Redis 自己设计了一个链表数据结构。 链表结构设计 typedef struct list {//链表头节点listNode *head;//链表尾…

【Matlab】智能优化算法_流向算法FDA

【Matlab】智能优化算法_流向算法FDA 1.背景介绍2.数学模型3.文件结构4.算法流程图5.详细代码及注释5.1 FDA.m5.2 initialization.m5.3 main.m5.4 Select_Functions.m 6.运行结果7.参考文献 1.背景介绍 在流域中&#xff0c;过量或有效降雨量是指流过地表且未渗入土壤的降雨量。…

使用可视化数据库工具 DBeaver

新建一个名为 test 的数据库&#xff1a;右击数据库点击新增&#xff0c;然后创建一张 test &#xff0c;utf8mb4 字符的&#xff0c;点击确定 在 test 数据库下新建一张数据表&#xff0c;如下所示&#xff1a;右击表&#xff0c;然后点击新建表 鼠标放列上面&#xff0c;右键…

安全狗重磅发布数据资产梳理系统

今年6月&#xff0c;浙江某科技有限公司因违反《中华人民共和国数据安全法》第四十五条及相关规定&#xff0c;公司及项目主管人员、直接责任人员分别罚款100万元、8万元、6万元。这也是《数据安全法》开始运行以来的首例“高额罚单”案件。实际上&#xff0c;这也给我国众多行…

002 Jetpack Compose基础组件学习

1.Text组件 Text组件就是原先的TextView组件&#xff0c;用法还是挺简单的&#xff0c;如下就是简单的Text用法&#xff1a; package com.test.composeimport android.os.Bundle import androidx.activity.ComponentActivity import androidx.activity.compose.setContent im…

(搜狗输入法)自定义输入日期格式

需求 想要按特定格式快速输入当天的日期戳&#xff1a;XXXX-XX-XX&#xff0c;如 2023-07-13 方法 参考链接&#xff1a;搜狗输入时间日期格式输入及自定义 按上述教程操作&#xff0c;自定义短语表达式&#xff1a;#$year-$month_mm-$day_dd 即可实现用搜狗输入法输入“r…

Table Recognition Metric: 表格识别算法评测工具包及相关评测基准数据集

Table Recognition Metric 该库用于计算TEDS指标&#xff0c;用来评测表格识别算法效果。可与魔搭-表格识别测试集配套使用。TEDS计算代码参考&#xff1a;PaddleOCR 和 DAVAR-Lab-OCR 使用说明&#xff1a; Install package by pypi.pip install table_recognition_metricRu…