〔 MySQL 〕数据类型

目录

1.数据类型分类

2 数值类型

2.1 tinyint类型

2.2 bit类型

2.3 小数类型

2.3.1 float

2.3.2 decimal

3 字符串类型

3.1 char

3.2 varchar

3.3 char和varchar比较

4 日期和时间类型

5 enum和set


mysql表中建立属性列:

        列名称,类型在后

        num tinyint unsinged

1.数据类型分类

2 数值类型

2.1 tinyint类型

数值越界测试:

mysql> create table tt1(num tinyint);
Query OK, 0 rows affected (0.02 sec)mysql> insert into t1 values(1);
Query OK, 1 row affected (0.00 sec)mysql> insert into t1 values(128); -- 越界插入,报错
ERROR 1264 (22003): Out of range value for column 'num' at row 1mysql> select * from t1;
+------+
| num |
+------+
| 1 |
+------+
1 row in set (0.00 sec)

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

mysql> create table t2(num tinyint unsigned);
mysql> insert into t2 values(-1); -- 无符号,范围是: 0 - 255
ERROR 1264 (22003): Out of range value for column 'num' at row 1mysql> insert into t2 values(255);
Query OK, 1 row affected (0.02 sec)mysql> select * from t2;
+------+
| num |
+------+
| 255 |
+------+
1 row in set (0.00 sec)

 会发现如果我们向mysql特定的类型中插入不合法的数据,MySQL一般都是直接拦截,不让进行对应的操作;

相反,如果我们已经有数据被成功插入到mysql中,插入的数据一定是合法的;

所以,在mysql中,一般而言,数据类型本身也是一种: 约束 

约束:倒逼程序员,让程序员尽可能进行正确的插入。约束使用者!

另外,如果你不是一个很好的使用者,mysql也能保证数据插入的合法性。

这样就能保证数据库中的数据是可预期的,完整的。

●  其他类型自己推导

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

2.2 bit类型

基本语法:

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

举例:

mysql> create table t3 ( id int, a bit(8));
Query OK, 0 rows affected (0.01 sec)mysql> insert into t3 values(10, 10);
Query OK, 1 row affected (0.01 sec)mysql> select * from t3; #发现很怪异的现象,a的数据10没有出现
+------+------+
| id | a |
+------+------+
| 10 | |
+------+------+
1 row in set (0.00 sec)

bit使用的注意事项:
  ●  bit字段在显示时,是按照ASCII码对应的值显示。

mysql> insert into t3 values(65, 65);
mysql> select * from tt4;
+------+------+
| id | a |
+------+------+
| 10 | |
| 65 | A |
+------+------+

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

mysql> create table t4(gender bit(1));
mysql> insert into t4 values(0);
Query OK, 1 row affected (0.00 sec)mysql> insert into t4 values(1);
Query OK, 1 row affected (0.00 sec)mysql> insert into t4 values(2); -- 当插入2时,已经越界了
ERROR 1406 (22001): Data too long for column 'gender' at row 1

2.3 小数类型


2.3.1 float
 

语法:

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

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

mysql> create table t5(id int, salary float(4,2));
Query OK, 0 rows affected (0.01 sec)mysql> insert into t5 values(100, -99.99);
Query OK, 1 row affected (0.00 sec)mysql> insert into t5 values(101, -99.991); #多的这一点被拿掉了
Query OK, 1 row affected (0.00 sec)mysql> select * from t5;
+------+--------+
| id | salary |
+------+--------+
| 100 | -99.99 |
| 101 | -99.99 |
+------+--------+
2 rows in set (0.00 sec)

问题: 当我们的float(4,2)如果是一个有符号的,则表示范围是-99.99 ~ 99.99,如果float(6,3),猜一下范围是多少?

-999.999~999.999

案例:

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

mysql> create table t6(id int, salary float(4,2) unsigned);
Query OK, 0 rows affected (0.01 sec)mysql> insert into t6 values(100, -0.1);
Query OK, 1 row affected, 1 warning (0.00 sec)mysql> show warnings;
+---------+------+-------------------------------------------------+
| Level | Code | Message |
+---------+------+-------------------------------------------------+
| Warning | 1264 | Out of range value for column 'salary' at row 1 |
+---------+------+-------------------------------------------------+
1 row in set (0.00 sec)mysql> insert into t6 values(100, -0);
Query OK, 1 row affected (0.00 sec)mysql> insert into t6 values(100, 99.99);
Query OK, 1 row affected (0.00 sec)

2.3.2 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 t7 ( id int, salary float(10,8), salary2
decimal(10,8));mysql> insert into t7 values(100,23.12345612, 23.12345612);
Query OK, 1 row affected (0.00 sec)mysql> select * from t7;
+------+-------------+-------------+
| id | salary | salary2 |
+------+-------------+-------------+
| 100 | 23.12345695 | 23.12345612 | # 发现decimal的精度更准确,因此如果我们希望某
个数据表示高精度,选择decimal
+------+-------------+-------------+

说明:float表示的精度大约是7位。
    ● decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0.如果m被省           略,默认是10。

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

3 字符串类型


3.1 char
 

语法:

char(2) 表示可以存放两个字符,可以是字母或汉字,但是不能超过2个, 最多只能是255

案例(char):

mysql> create table t8(id int, name char(2));
Query OK, 0 rows affected (0.00 sec)mysql> insert into  t8 values(100, 'ab');
Query OK, 1 row affected (0.00 sec)mysql> insert into  t8 values(101, '中国');
Query OK, 1 row affected (0.00 sec)mysql> select * from t8;
+------+--------+
| id | name |
+------+--------+
| 100 | ab |
| 101 | 中国 |
+------+--------+
mysql> create table t8(id int ,name char(256));
ERROR 1074 (42000): Column length too big for column 'name' (max = 255); use
BLOB or TEXT instead
varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节

说明:

char(2) 表示可以存放两个字符,可以是字母或汉字,但是不能超过2个, 最多只能是255

mysql> create table t8(id int ,name char(256));
ERROR 1074 (42000): Column length too big for column 'name' (max = 255); 
use BLOB or TEXT instead

3.2 varchar


语法:

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

案例:
 

mysql> create table t9(id int ,name varchar(6)); --表示这里可以存放6个字符
mysql> insert into t9 values(100, 'hello');
mysql> insert into t9 values(100, '我爱你,中华');
mysql> select * from t9;
+------+--------------------+
| id | name |
+------+--------------------+
| 100 | hello |
| 100 | 我爱你,中华 |
+------+--------------------+

说明:

关于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 t10(name varchar(21845))charset=utf8; --验证了
utf8确实是不能超过21844ERROR 1118 (42000): Row size too large. The maximum row size for the used
table type, not counting BLOBs, is 65535. You have to change some columns to
TEXT or BLOBsmysql> create table t10(name varchar(21844)) charset=utf8;Query OK, 0 rows affected (0.01 sec)

3.3 char和varchar比较

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

    ● 如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5
    ● 如果数据长度有变化,就使用变长(varchar), 比如:名字,地址,但是你要保证最长的能存的进去。
    ● 定长的磁盘空间比较浪费,但是效率高。
    ● 变长的磁盘空间比较节省,但是效率低。
    ● 定长的意义是,直接开辟好对应的空间
    ● 变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。

4 日期和时间类型


常用的日期有如下三个:

    ● 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 birthday (t1 date, t2 datetime, t3 timestamp);
Query OK, 0 rows affected (0.01 sec)//插入数据:mysql> insert into birthday(t1,t2) values('1997-7-1','2008-8-8 12:1:1'); --插入
两种时间
Query OK, 1 row affected (0.00 sec)mysql> select * from birthday;
+------------+---------------------+---------------------+
| t1 | t2 | t3 |
+------------+---------------------+---------------------+
| 1997-07-01 | 2008-08-08 12:01:01 | 2024-11-12 18:28:55 | --添加数据时,时间戳自动补
上当前时间
+------------+---------------------+---------------------+//更新数据:mysql> update birthday set t1='2000-1-1';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0mysql> select * from birthday;
+------------+---------------------+---------------------+
| t1 | t2 | t3 |
+------------+---------------------+---------------------+
| 2000-01-01 | 2008-08-08 12:01:01 | 2024-11-12 18:32:09 | -- 更新数据,时间戳会更新
成当前时间
+------------+---------------------+---------------------+

5 enum和set


语法:

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

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

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

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

说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。

案例:
有一个调查表votes,需要调查人的喜好, 比如(跑步,羽毛球,篮球,乒乓球)中去选择(可以多选),(男,女)[单选]

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

-- 插入雷锋的数据
INSERT INTO votes (username, hobby, gender) VALUES ('雷锋', '跑步,乒乓球', '男');
-- 插入Juse的数据
INSERT INTO votes (username, hobby, gender) VALUES ('Juse', '跑步,乒乓球', '女');
-- 插入LiLei(跑步)的数据
INSERT INTO votes (username, hobby, gender) VALUES ('LiLei', '跑步', '男');
-- 插入LiLei(篮球)的数据,这里假设在业务逻辑上同一个username可以有不同的爱好记录
INSERT INTO votes (username, hobby, gender) VALUES ('LiLei', '篮球', '男');
-- 插入HanMeiMei的数据
INSERT INTO votes (username, hobby, gender) VALUES ('HanMeiMei', '羽毛球', '女');

有如下数据,想查找所有喜欢登山的人:

+-----------+---------------+--------+
| username | hobby | gender |
+-----------+---------------+--------+
| 雷锋 | 跑步,乒乓球 | 男 |
| Juse | 跑步,乒乓球 | 女 |
| LiLei | 跑步 | 男 |
| LiLei | 篮球 | 男 |
| HanMeiMei | 羽毛球 | 女 |
+-----------+---------------+--------+

使用如下查询语句:
 

mysql> select * from votes where hobby='跑步';
+----------+--------+--------+
| username | hobby | gender |
+----------+--------+--------+
| LiLei | 跑步 | 男 |
+----------+--------+--------+

不能查询出所有,爱好为跑步的人。
集合查询使用find_ in_ set函数:
find_in_set(sub,str_list) :如果 sub 在 str_list 中,则返回下标;如果不在,返回0;
str_list 用逗号分隔的字符串
 

mysql> select * from votes where find_in_set('a', 'a,b,c');
+---------------------------+
| find_in_set('a', 'a,b,c') |
+---------------------------+
| 1 |
+---------------------------+mysql> select * from votes where find_in_set('d', 'a,b,c');
+---------------------------+
| find_in_set('d', 'a,b,c') |
+---------------------------+
| 0 |
+---------------------------+

查询爱好跑步的人:
 

mysql> select * from votes where find_in_set('登山', hobby);
+----------+---------------+--------+
| username | hobby | gender |
+----------+---------------+--------+
| 雷锋 | 跑步,乒乓球 | 男 |
| Juse | 跑步,乒乓球 | 女 |
| LiLei | 跑步 | 男 |
+----------+---------------+--------+

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

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

相关文章

LlamaIndex

一、大语言模型开发框架 SDK:Software Development Kit,它是一组软件工具和资源的集合,旨在帮助开发者创建、测试、部署和维护应用程序或软件。 所有开发框架(SDK)的核心价值,都是降低开发、维护成本。 大语言模型开发框架的价值,是让开发者可以更方便地开发基于大语言…

【FFmpeg】FFmpeg 函数简介 ③ ( 编解码相关函数 | FFmpeg 源码地址 | FFmpeg 解码器相关 结构体 和 函数 )

文章目录 一、FFmpeg 解码器简介1、解码流程分析2、FFmpeg 编解码器 本质3、FFmpeg 编解码器 ID 和 名称 二、FFmpeg 解码器相关 结构体 / 函数1、AVFormatContext 结构体2、avcodec_find_decoder 函数 - 根据 ID 查找 解码器3、avcodec_find_decoder_by_name 函数 - 根据 名称…

Linux——GPIO输入输出裸机实验

学习了正点原子Linux环境下的GPIO的输入输出的裸机实验学习,现在进行一下小结: 启动文件start.S的编写 .global _start .global _bss_start _bss_start:.word __bss_start.global _bss_end _bss_end:.word __bss_end_start:/*设置处理器进入SVC模式*/m…

zabbix搭建钉钉告警流程

目录 🌤️zabbix实验规划 🌤️zabbix实验步骤 📑1 使用钉钉添加一个自定义的机器人 ​ 📑2在zabbix-server上编写钉钉信息发送脚本,设置钉钉报警媒介 ☁️ 设置钉钉报警媒介​编辑​编辑 ☁️在添加消息模板​编辑​…

Java 多线程(三)—— 死锁

死锁的产生 我们先从简单的死锁最后到难一些的死锁问题开始展开讨论。 首先一个线程,一把锁,因为多次加锁而导致死锁问题,由于Java 的synchronized 实现了可重入锁,因此这个死锁问题就不存在了,意味着当一个线程拥有…

makefile 设置动态库路径参数

目录 一、makefile 动态库相关1.1 Libs 变量1.2 LDFLAGS 变量1.3 二者的作用和区别 二、设置方式2.1 编译时指定库路径2.2 运行时指定库路径 三、测试 一、makefile 动态库相关 1.1 Libs 变量 在 Makefile 中,Libs 通常是一个变量,用于存储链接器&…

Servlet入门 Servlet生命周期 Servlet体系结构

一.Servlet入门 1.Servlet介绍 Servlet (server applet) 是运行在服务端(tomcat)的Java小程序,是sun公司提供一套定义动态资源规范; 从代码层面上来讲Servlet就是一个接口 狭义的Servlet是指Java语言编写的一个接口。 广义的Servlet是指任何实现了这个Servlet接口…

穿越数据迷宫:C++哈希表的奇幻旅程

文章目录 前言📔一、unordered系列关联式容器📕1.1 unordered 容器概述📕1.2 哈希表在 unordered 容器中的实现原理📕1.3 unordered 容器的特点 📔二、unordered_set 和 unordered_map 的基本操作📕2.1 un…

飞牛云fnOS本地部署WordPress个人网站并一键发布公网远程访问

文章目录 前言1. Docker下载源设置2. Docker下载WordPress3. Docker部署Mysql数据库4. WordPress 参数设置5. 飞牛云安装Cpolar工具6. 固定Cpolar公网地址7. 修改WordPress配置文件8. 公网域名访问WordPress 前言 本文旨在详细介绍如何在飞牛云NAS上利用Docker部署WordPress&a…

2023年MathorCup数学建模B题城市轨道交通列车时刻表优化问题解题全过程文档加程序

2023年第十三届MathorCup高校数学建模挑战赛 B题 城市轨道交通列车时刻表优化问题 原题再现: 列车时刻表优化问题是轨道交通领域行车组织方式的经典问题之一。列车时刻表规定了列车在每个车站的到达和出发(或通过)时刻,其在实际…

安全见闻1-5

涵盖了编程语言、软件程序类型、操作系统、网络通讯、硬件设备、web前后端、脚本语言、病毒种类、服务器程序、人工智能等基本知识,有助于全面了解计算机科学和网络技术的各个方面。 安全见闻1 1.编程语言简要概述 C语言:面向过程,适用于系统…

闯关leetcode——3178. Find the Child Who Has the Ball After K Seconds

大纲 题目地址内容 解题代码地址 题目 地址 https://leetcode.com/problems/find-the-child-who-has-the-ball-after-k-seconds/description/ 内容 You are given two positive integers n and k. There are n children numbered from 0 to n - 1 standing in a queue in o…

Java结合ElasticSearch根据查询关键字,高亮显示全文数据。

由于es高亮显示机制的问题。当全文内容过多,且搜索中标又少时,就会出现高亮结果无法覆盖全文。因此需要根据需求手动替换。 1.根据es的ik分词器获取搜索词的分词结果。 es部分: //中文分词解析 post /_analyze {"analyzer":"…

Python——NumPy库的简单用法,超级详细教程使用

一、什么是NumPy库 NumPy:它是python的一个科学计算库函数,它是由c语言编写的 它应用于数据处理、机器学习、图像处理、文件操作等等 二、array函数 这里导入库numpy,命名为np,后面的np都是代表着是numpy函数 array函数表示创建…

【Java语言】String类

在C语言中字符串用字符可以表示,可在Java中有单独的类来表示字符串(就是String),现在我来介绍介绍String类。 字符串构造 一般字符串都是直接赋值构造的,像这样: 还可以这样构造: 图更能直观的…

自由学习记录(21)

感觉反而 还复杂一点,关系并不纯粹,游戏里用的少...的确 是知道为什么游戏不用了 理解思想就可以了,实际操作也是动态的分析,硬套某种模式也不是怎么很合适 MVC的了解应该是差不多了,重点还是实际中的使用了 所以删了…

Bugku CTF_Web——点login咋没反应

Bugku CTF_Web——点login咋没反应 进入靶场 随便输个试试 看来确实点login没反应 抓包看看 也没有什么信息 看了下源码 给了点提示 一个admin.css try ?12713传参试试 拿到一个php代码 <?php error_reporting(0); $KEYctf.bugku.com; include_once("flag.php&q…

软件测试面试大全(含答案+文档)

1、你的测试职业发展是什么&#xff1f; 测试经验越多&#xff0c;测试能力越高。所以我的职业发展是需要时间积累的&#xff0c;一步步向着高级测试工程师奔去。而且我也有初步的职业规划&#xff0c;前3年积累测试经验&#xff0c;按如何做好测试工程师的要点去要求自己&…

从华为到创业公司

我有一个朋友&#xff0c;在华为工作了很长一段时间&#xff0c;一年多前&#xff0c;他从华为出来到了一家创业公司。 周末趁着有时间&#xff0c;我跟他聊了下关于从华为到创业公司的一些问题&#xff0c;总结给大伙看看。 ▎1 在华为工作和在创业公司工作最大的差别是什么呢…

Linux网络——网络初识

目录 1. 认识协议 2. 协议的分层 3. OSI 七层模型 && TCP/IP 五层(四层)模型 4. 网络传输的基本流程 5. 以太网的通信原理 6. 数据的跨网络传播 7. 认识 IP 地址 ① IP 是什么 ② IP 与 MAC 的关系 ③ 为什么需要 IP 在谈及网络之前&#xff0c;我们要先对学…