MySQL数据库数据类型

news2024/11/24 6:06:38

MySQL数据库数据类型分类 

在MySQL数据库中,MySQL数据类型分有四大类:数值类型、文本/二进制类型、时间日期和String类型。以下是这四大类的具体类型:

 数值类型

数值类型的范围和字节大小:

tinyint类型

tinyint类型只有一个字节大小,其数据范围为:【-128,127】

有符号举例:

mysql> create table tt1(  --创建表,字段只有num,类型为tinyint
    -> num tinyint
    -> );
Query OK, 0 rows affected (0.04 sec)

mysql> insert into tt1 values(1);   --成功
Query OK, 1 row affected (0.00 sec)

mysql> insert into tt1 values(127);  --成功
Query OK, 1 row affected (0.00 sec)

mysql> insert into tt1 values(128);   --越界
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> select * from tt1;
+------+
| num  |
+------+
|    1 |
|  127 |
+------+
2 rows in set (0.00 sec)

说明:

在MySQL中,整型可以指定是有符号的和无符号的,默认是有符号的。可以通过UNSIGNED来说明某个字段是无符号的。

无符号举例:

mysql> create table tt2(   --tt2表,只有num字段,类型为tinyiny unsigned,表示无符号
    -> num tinyint unsigned);
Query OK, 0 rows affected (0.04 sec)

mysql> insert into tt2 values(-1);  --数值范围在【0,255】
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into tt2 values(255);  --成功
Query OK, 1 row affected (0.01 sec)

mysql> select * from tt2;
+------+
| num  |
+------+
|  255 |
+------+
1 row in set (0.00 sec)

温馨提示:尽量不使用unsigned,对于int类型可能存放不下的数据,int unsigned同样可能存放不下,与其如此,还不如设计时,将int类型提升为bigint类型。

bit类型

基本语法:

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

举例:

mysql> create table tt3(  --创建tt3表,字段有id 类型为int,a 类型为bit(8).表示有8位比特位
    -> id int,
    -> a bit(8)
    -> );
Query OK, 0 rows affected (0.03 sec)

mysql> insert into tt3 values(10,10);  --插入数据
Query OK, 1 row affected (0.00 sec)

mysql> select * from tt3;  --在显示的时候,会发现一个奇怪的问题,a的值没有显示
+------+------+
| id   | a    |
+------+------+
|   10 | 
+------+------+
1 row in set (0.00 sec)

我们会发现,在查询tt3表的时候,a的值没有显示出来。原来,bit字段在显示时,是按照ASCII码对应的值显示的,比如这样子:

mysql> insert into tt3 values(65,65);
Query OK, 1 row affected (0.00 sec)

mysql> select * from tt3;
+------+------+
| id   | a    |
+------+------+
|   10 | 
    |
|   65 | A    |
+------+------+
2 rows in set (0.00 sec)

查询出来的结果可以很清楚,65对应就是A,而10,对应的是换行键LF,因此没有显示出来。

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

mysql> create table tt4(
    -> gender bit(1)
    -> );
Query OK, 0 rows affected (0.03 sec)

mysql> insert into tt4 values(0);
Query OK, 1 row affected (0.01 sec)

mysql> insert into tt4 values(1);
Query OK, 1 row affected (0.01 sec)

mysql> insert into tt4 values(2); --当插入2的时候报错
ERROR 1406 (22001): Data too long for column 'gender' at row 1

小数类型

float类型

语法:

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

举例:

小数:float(4,2)表示的范围是-99.99 ~ 99.99,MySQL在保存值时会进行四舍五入。

mysql> create table tt5(
    -> id int,
    -> salary float(4,2)
    -> );
Query OK, 0 rows affected (0.03 sec)

mysql> insert into tt5 values(100,99.99);
Query OK, 1 row affected (0.00 sec)

mysql> insert into tt5 values(101,-99.99);
Query OK, 1 row affected (0.01 sec)

mysql> insert into tt5 values(102,99.991); --多的这一点被拿掉
Query OK, 1 row affected (0.00 sec)

mysql> insert into tt5 values(103,-99.991);
Query OK, 1 row affected (0.00 sec)

mysql> insert into tt5 values(104,-99.995);  --四舍五入会失败,由于定义了长度为4,小数位为2,不能变成100.00
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> select * from tt5;
+------+--------+
| id   | salary |
+------+--------+
|  100 |  99.99 |
|  101 | -99.99 |
|  102 |  99.99 |  
|  103 | -99.99 |
+------+--------+
4 rows in set (0.00 sec)

如果定义的是float(4,2) unsigned 这时,因为把它指定为无符号的数,范围是:0 ~ 99.99

mysql> create table tt6(
    -> id int,
    -> salary float(4,2) unsigned);
Query OK, 0 rows affected (0.03 sec)

mysql> insert into tt6 values(100,-0.1);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into tt6 values(100,-0);
Query OK, 1 row affected (0.01 sec)

mysql> insert into tt6 values(100,99.99);
Query OK, 1 row affected (0.00 sec)

mysql> select * from tt6;
+------+--------+
| id   | salary |
+------+--------+
|  100 |   0.00 |
|  100 |  99.99 |
+------+--------+
2 rows in set (0.00 sec)

decimal类型

语法:

decimal(m, d) [unsigned] : 定点数m指定长度,d表示小数点的位数

decimal(5,2) 表示的范围是 -999.99 ~ 999.99。decimal(5,2) unsigned 表示的范围 0 ~ 999.99。

decimal和float很像,但是有区别:float和decimal表示的精度不一样。

mysql> create table tt7(
    -> id int,
    -> salary float(10,8),
    -> salary2 decimal(10,8)
    -> );
Query OK, 0 rows affected (0.03 sec)

mysql> insert into tt7 values(100,23.12345612,12.12345612);
Query OK, 1 row affected (0.00 sec)

mysql> select * from tt7;   --# 发现decimal的精度更准确,因此如果我们希望某个数据表示高精度,选择decimal
+------+-------------+-------------+
| id   | salary      | salary2     |
+------+-------------+-------------+
|  100 | 23.12345695 | 12.12345612 |
+------+-------------+-------------+
1 row in set (0.00 sec)

说明:float表示的精度大约是7位。decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0。如果m被省略,默认是10。因此如果希望小数的精度高,推荐使用decimal。

字符串类型

char类型

语法:

char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255

举例:

mysql> create table tt8(
    -> id int,
    -> name char(2)
    -> );
Query OK, 0 rows affected (0.03 sec)

mysql> insert into tt8 values(100,'ab');
Query OK, 1 row affected (0.01 sec)

mysql> insert into tt8 values(100,'汉族');
Query OK, 1 row affected (0.00 sec)

mysql> select * from tt8;
+------+--------+
| id   | name   |
+------+--------+
|  100 | ab     |
|  100 | 汉族   |
+------+--------+
2 rows in set (0.00 sec)

说明:

在MySQL中,char(2)可以存放两个字符,但是不能超过2个,.CHAR最多只能是char(255),不管是汉族还是字母还是什么,因为在MySQL中,一个字符就是一个字符,一个单词,一个汉字的意思。

varchar类型

语法:

varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节

举例:

mysql> create table tt9(
    -> id int,
    -> name varchar(6));  --表示可以存放6个字符
Query OK, 0 rows affected (0.04 sec)

mysql> insert into tt9 values(100,'hello');
Query OK, 1 row affected (0.00 sec)

mysql> insert into tt9 values(101,'我爱你,中国');
Query OK, 1 row affected (0.01 sec)

mysql> select * from tt9;
+------+--------------------+
| id   | name               |
+------+--------------------+
|  100 | hello              |
|  101 | 我爱你,中国       |
+------+--------------------+
2 rows in set (0.00 sec)

说明:

关于varchar(len),len到底是多大,这个len值,和表的编码密切相关:varchar长度可以指定为0到65535之间的值,但是有1 - 3 个字节用于记录数据大小,所以说有效字节数是65532。

当我们的表的编码是utf8时,varchar(n)的参数n最大值是65532/3=21844[因为utf中,一个字符占
用3个字节],如果编码是gbk,varchar(n)的参数n最大是65532/2=32766(因为gbk中,一个字符占用2字节)

mysql> create table tt10(
    -> name varchar(21845)) charset=utf8;  --验证了utf8确实是不能超过21844
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. 
This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs

mysql> create table tt10( name varchar(21844)) charset=utf8;
Query OK, 0 rows affected (0.03 sec)

char和varchar的比较

如何选择定长或变长字符串?

如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5。

如果数据长度有变化,就使用变长(varchar), 比如:名字,地址,但是你要保证最长的能存的进去。

定长的磁盘空间比较浪费,但是效率高。

变长的磁盘空间比较节省,但是效率低。

定长的意义是,直接开辟好对应的空间。

变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。

日期和时间类型

常用的日期有如下三个:

date日期: 'yyyy-mm-dd' ,占用三字节。
datetime时间日期格式: 'yyyy-mm-dd HH:ii:ss' 表示范围从 1000 到 9999 ,占用八字节。
timestamp时间戳:从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节。

举例:分别给出这三种日期时间类型的数据。

mysql> create table tt11(
    -> t1 date,
    -> t2 datetime,
    -> t3 timestamp);
Query OK, 0 rows affected (0.04 sec)

mysql> insert into tt11(t1,t2) values('2023-8-2','2023-9-1 12:1:1');  --插入两种类型
Query OK, 1 row affected (0.01 sec)

mysql> select * from tt11;
+------------+---------------------+------------------------+
| t1                 | t2                            | t3                                 |
+------------+---------------------+------------------------+
| 2023-08-02 | 2023-09-01 12:01:01 | 2023-08-02 20:56:25 |      --时间戳会自动写上
+------------+---------------------+---------------------+
1 row in set (0.00 sec)

enum和set

语法:

enum:枚举,“单选”类型;enum('选项1','选项2','选项3',...);

该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,3,....最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。

set:集合,“多选”类型;set('选项值1','选项值2','选项值3', ...);

该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,....最多64个。

举例:

建表:

mysql> create table votes(
    -> username varchar(32),
    -> hobby set('篮球','唱跳','武术','游泳','跑步'),--注意:使用数字标识每个爱好的时候,想想
--Linux权限,采用比特位位置来个set中的爱好对应起来
    -> gender enum('男','女') --注意:使用数字标识的时候,就是正常的数组下标
    -> );
Query OK, 0 rows affected (0.03 sec)

插入数据:

mysql> insert into votes values('张三','登山,武术','男');
ERROR 1265 (01000): Data truncated for column 'hobby' at row 1
mysql> insert into votes values('张三','跑步,武术','男');
Query OK, 1 row affected (0.01 sec)

mysql> insert into votes values('Amy','游泳,唱跳','2');
Query OK, 1 row affected (0.01 sec)

mysql> select * from votes;
+----------+---------------+--------+
| username | hobby         | gender |
+----------+---------------+--------+
| 张三     | 武术,跑步     | 男     |
| Amy      | 唱跳,游泳     | 女     |
+----------+---------------+--------+
2 rows in set (0.00 sec)

mysql> insert into votes values('李四','跑步','1');
Query OK, 1 row affected (0.00 sec)

mysql> insert into votes values('王五','篮球','1');
Query OK, 1 row affected (0.01 sec)

mysql> insert into votes values('赵六','游泳,篮球','1');
Query OK, 1 row affected (0.00 sec)

mysql> select * from votes;
+----------+---------------+--------+
| username | hobby         | gender |
+----------+---------------+--------+
| 张三     | 武术,跑步     | 男     |
| Amy      | 唱跳,游泳     | 女     |
| 李四     | 跑步          | 男     |
| 王五     | 篮球          | 男     |
| 赵六     | 篮球,游泳     | 男     |
+----------+---------------+--------+
5 rows in set (0.00 sec)

查找所有喜欢跑步的人:

mysql> select * from votes where hobby='跑步';
+----------+--------+--------+
| username | hobby  | gender |
+----------+--------+--------+
| 李四     | 跑步   | 男     |
+----------+--------+--------+
1 row in set (0.00 sec)

不能查询出所有,爱好为跑步的人。只能查询到,单纯只有跑步的人。

集合查询使用find_ in_ set函数:

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

mysql> select find_in_set('a','a,b,c');
+--------------------------+
| find_in_set('a','a,b,c') |
+--------------------------+
|                        1 |
+--------------------------+
1 row in set (0.00 sec)

mysql> select find_in_set('z','a,b,c');
+--------------------------+
| find_in_set('z','a,b,c') |
+--------------------------+
|                        0 |
+--------------------------+
1 row in set (0.00 sec)

 查找所有喜欢跑步的人:

mysql> select * from votes where find_in_set('跑步',hobby);
+----------+---------------+--------+
| username | hobby         | gender |
+----------+---------------+--------+
| 张三     | 武术,跑步     | 男     |
| 李四     | 跑步          | 男     |
+----------+---------------+--------+
2 rows in set (0.00 sec)

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

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

相关文章

【雕爷学编程】Arduino动手做(180)---Seeeduino Lotus开发板

37款传感器与执行器的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止这37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的&am…

BGP汇总和破解水平分割

一,BGP的宣告问题 在BGP协议中每台运行BGP的设备上,宣告本地直连路由在BGP协议中运行BGP协议的设备来宣告,通过IGP学习到的,未运行BGP协议设备产生的路由; 在BGP协议中宣告本地路由表中路由条目时,将携带本…

葡萄叶病害数据集

1.数据集 分成训练集和测试集 训练集有四个文件夹 第一个文件夹为 Grape Black Measles(葡萄黑麻疹)病害(3783张) Grape Black rot葡萄黑腐病病害数据集(3596张) Grape Healthy 健康葡萄叶(25…

【【胎教级51单片机智能小车设计】】

胎教级51单片机智能小车设计 从现在开始开一个新坑 称为创意工坊 主要更新一些有意思的设计 第一次手把手更新51单片机智能小车 胎教级教学人人都会 单片机实现的功能是通过蓝牙APP 控制小车前后左右移动 先讲明白这个小车 后续再在这个小车上更新其他的设计 成品图 第一步…

《Java-SE-第二十六章》之线程池

前言 在你立足处深挖下去,就会有泉水涌出!别管蒙昧者们叫嚷:“下边永远是地狱!” 博客主页:KC老衲爱尼姑的博客主页 博主的github,平常所写代码皆在于此 共勉:talk is cheap, show me the code 作者是爪哇岛的新手,水平很有限&…

pytorch基础实践1

数据预处理的最终目的是将我们正在处理的任何数据转换成能够感知我们神经网络的张量 基本概念 CNN的输入tensor 一般CNN的输入是一个4阶张量,分别用一个字母代表每个axis上的长度,那么它的shape为: [B,C,H,W] 其中 H 和 W 分别代表输入的单…

北邮22信通:第五章 邻接表图的广度遍历和深度遍历

北邮22信通一枚~ 跟随课程进度每周更新数据结构与算法的代码和文章 持续关注作者 解锁更多邮苑信通专属代码~ 获取更多文章 请访问专栏: 北邮22信通_青山如墨雨如画的博客-CSDN博客 目录 一.总纲 二.构造函数 2.1构造函数讲解 2.2构造函数的书写 书…

echars力引导关系图

效果图 力引导关系图 力引导布局是模拟弹簧电荷模型在每两个节点之间添加一个斥力,每条边的两个节点之间添加一个引力,每次迭代节点会在各个斥力和引力的作用下移动位置,多次迭代后节点会静止在一个受力平衡的位置,达到整个模型…

Java项目-苍穹外卖-Day01

文章目录 博客介绍软件开发流程项目介绍产品原型技术选型 博客介绍 从头开始做黑马的苍穹外卖项目 每天记录一下新学的知识点以及对应的开发进度 然后一些在项目中遇到的问题会重点标注 本篇主要是后端的,前端会一笔带过 软件开发流程 流程介绍需求分析需求规格说…

使用pg_prewarm缓存PostgreSQL数据库表

pg_prewarm pg_prewarm 直接利用系统缓存的代码,对操作系统发出异步prefetch请求,在应用中,尤其在OLAP的情况下,对于大表的分析等等是非常耗费查询的时间的,而即使我们使用select table的方式,这张表也并不可能将所有…

Eureka 学习笔记2:EurekaClient

版本 awsVersion ‘1.11.277’ EurekaClient 接口实现了 LookupService 接口&#xff0c;拥有唯一的实现类 DiscoveryClient 类。 LookupService 接口提供以下功能&#xff1a; 获取注册表根据应用名称获取应用根据实例 id 获取实例信息 public interface LookupService<…

【LeetCode】141. 环形链表 进阶题142. 环形链表 II

141. 环形链表 这道题还是用经典的快慢指针法来做。每次让快的指针走两步&#xff0c;慢的走一步。如果有环&#xff0c;则绝对会在环内的某一节点相遇。思想跟物理知识有点关系&#xff0c;如果有环&#xff0c;则在相对运动过程中&#xff0c;可以相当于慢指针静止&#xff0…

STM32入门——外部中断

中断系统概述 中断&#xff1a;在主程序运行过程中&#xff0c;出现了特定的中断触发条件&#xff08;中断源&#xff09;&#xff0c;使得CPU暂停当前正在运行的程序&#xff0c;转而去处理中断程序&#xff0c;处理完成后又返回原来被暂停的位置继续运行中断优先级&#xff…

Java集合数组相互转换

1.集合转换成数组 &#xff08;1&#xff09;集合a通过toArray()方法进行转换为数组&#xff0c;可以转换成为指定类型的数组&#xff0c;但是这些类型都必须是object类型的子类&#xff0c;基本类型不可以。 必要时我们使用强制类型转换&#xff0c;转成我们需要的类型。 Li…

【网络编程】poll

主旨思想 用一个结构体记录文件描述符集合&#xff0c;并记录用户态状态和内核态状态 函数说明 概览 #include <poll.h> struct pollfd { int fd; /* 委托内核检测的文件描述符 */ short events; /* 委托内核检测文件描述符的什么事件 */ short revents; /* 文件描述…

MySQL 远程操作mysql

可以让别人在他们的电脑上操作我电脑上的数据库 create user admin identified with mysql_native_password by admin; //设置账号密码都为admingrant all on *.* to admin; //给admin账号授权 授权完成

​五、驱动 - ​音频系统硬件电路

文章目录 1. 音频系统硬件电路结构2. 蓝牙音频2.1 音乐播放2.2 VoIP通话2.3 4G通话3. 其他3.1 什么是S/PDIF1. 音频系统硬件电路结构 录音放音设备:mic、speaker、耳机、听筒这些带有录音放音功能的设备(因为录放设备可能是模拟设备也可能是数字设备,所以接口可能是模拟接口…

IDEA中怎么使用git下载项目到本地,通过URL克隆项目(gitee\github)

点击 新建>来自版本控制的项目 点击后会弹出这样一个窗口 通过URL拉取项目代码 打开你要下载的项目仓库 克隆>复制 gitee github也是一样的 返回IDEA 将刚刚复制的URL粘贴进去选择合适的位置点击克隆 下载完成

JavaEE初阶之网络初识

一、网络发展史 1.1独立模式 独立模式:计算机之间相互独立; 1.2网络互连 随着时代的发展,越来越需要计算机之间互相通信,共享软件和数据,即以多个计算机协同工作来完成业务,就有了网络互连。网络互连:将多台计算机连接在一起,完成数据共享。 数据共享本质是网络数据…

【Python】5分钟了解11个最佳的Python编译器和解释器

11个最佳Python编译器和解释器 1. Brython2. Pyjs3. WinPython4. Skulpt5. Shed Skin6. Active Python7. Transcrypt8. Nutika9. Jython10. CPython11. IronPython结论原文链接 Python是一门初学者的编程语言。它是一种高级语言&#xff0c;非常灵活、解释性和面向对象的语言。…