【MySQL】5. 数据类型

数据类型

1. 数据类型分类

在这里插入图片描述

2. 数值类型

在这里插入图片描述

2.1 tinyint类型

数值越界测试:

mysql> use tt;
Database changed
mysql> create table t1(-> num tinyint-> );
Query OK, 0 rows affected (0.01 sec)mysql> insert into t1 values(-128);
Query OK, 1 row affected (0.00 sec)mysql> insert into t1 values(127);
Query OK, 1 row affected (0.00 sec)mysql> insert into t1 values(0);
Query OK, 1 row affected (0.00 sec)mysql> insert into t1 values(22);
Query OK, 1 row affected (0.00 sec)mysql> insert into t1 values(-23);
Query OK, 1 row affected (0.00 sec)mysql> insert into t1 values(-255);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into t1 values(-256);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> select * from t1;
+------+
| num  |
+------+
| -128 |
|  127 |
|    0 |
|   22 |
|  -23 |
+------+
5 rows in set (0.00 sec)

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

mysql> create table t2(-> num tinyint unsigned-> );
Query OK, 0 rows affected (0.01 sec)mysql> insert into t2 values(0);
Query OK, 1 row affected (0.00 sec)mysql> insert into t2 values(255);
Query OK, 1 row affected (0.00 sec)mysql> insert into t2 values(-1);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into t2 values(-2);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into t2 values(100);
Query OK, 1 row affected (0.00 sec)mysql> select * from t2;
+------+
| num  |
+------+
|    0 |
|  255 |
|  100 |
+------+
3 rows in set (0.00 sec)

其他类型自己推导(和tinyint类型类似,只不过就是范围的问题罢了)
在这里插入图片描述

2.2 bit类型

基本语法:

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

举例:

mysql> create table t3(-> id int,-> online bit(1)-> );
Query OK, 0 rows affected (0.01 sec)mysql> insert into t3 values(124,0);
Query OK, 1 row affected (0.00 sec)mysql> insert into t3 values(123,1);
Query OK, 1 row affected (0.00 sec)mysql> insert into t3 values(123,2);
ERROR 1406 (22001): Data too long for column 'online' at row 1
mysql> insert into t3 values(123,-1);
ERROR 1406 (22001): Data too long for column 'online' at row 1
mysql> select * from t3;
+------+--------+
| id   | online |
+------+--------+
|  124 |        |
|  123 |       |
+------+--------+
2 rows in set (0.00 sec)mysql> select id,hex(online) from t3;
+------+-------------+
| id   | hex(online) |
+------+-------------+
|  124 | 0           |
|  123 | 1           |
+------+-------------+
2 rows in set (0.00 sec)

这里我们发现单纯的select 无法显示online当中的数据(因为online中的数据是按位存储,无法直接显示)
可以通过hex方法(十六进制)的方式显示

mysql> create table t4(-> id int,-> bite bit(4)-> );
Query OK, 0 rows affected (0.02 sec)mysql> insert into t4 values(1,65);
Query OK, 1 row affected (0.00 sec)mysql> insert into t4 values(2,97);
Query OK, 1 row affected (0.00 sec)mysql> select * from t4;
+------+------+
| id   | bite |
+------+------+
|    1 | A    |
|    2 | a    |
+------+------+
2 rows in set (0.00 sec)

bit字段在显示时,是按照ASCII码对应的值显示。

2.3 小数类型

2.3.1 float

语法:

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

案例:
小数:float(4,2)表示的范围是-99.99 ~ 99.99

mysql> create table t5(-> id int,-> salary float(4,2)-> );
Query OK, 0 rows affected (0.01 sec)mysql> insert into t5 values(1,99.99);
Query OK, 1 row affected (0.01 sec)mysql> insert into t5 values(2,-99.99);
Query OK, 1 row affected (0.00 sec)mysql> insert into t5 values(2,-100.00);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t5 values(2,100.00);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> select * from t5;
+------+--------+
| id   | salary |
+------+--------+
|    1 |  99.99 |
|    2 | -99.99 |
+------+--------+
2 rows in set (0.00 sec)

MySQL在保存值时会进行四舍五入

mysql> insert into t5 values(3,78.668);
Query OK, 1 row affected (0.00 sec)mysql> insert into t5 values(3,99.994);
Query OK, 1 row affected (0.00 sec)mysql> insert into t5 values(4,-99.994);
Query OK, 1 row affected (0.00 sec)mysql> insert into t5 values(4,-99.998);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t5 values(4,99.998);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> select * from t5;
+------+--------+
| id   | salary |
+------+--------+
|    1 |  99.99 |
|    2 | -99.99 |
|    3 |  78.67 |
|    3 |  99.99 |
|    4 | -99.99 |
+------+--------+
5 rows in set (0.00 sec)

案例:
如果定义的是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(1,0);
Query OK, 1 row affected (0.01 sec)mysql> insert into t6 values(1,99.99);
Query OK, 1 row affected (0.00 sec)mysql> insert into t6 values(1,-0.0001);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t6 values(1,0.0001);
Query OK, 1 row affected (0.00 sec)mysql> select * from t6;
+------+--------+
| id   | salary |
+------+--------+
|    1 |   0.00 |
|    1 |  99.99 |
|    1 |   0.00 |
+------+--------+
3 rows in set (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> desc t7;
+---------+---------------+------+-----+---------+-------+
| Field   | Type          | Null | Key | Default | Extra |
+---------+---------------+------+-----+---------+-------+
| id      | int(11)       | YES  |     | NULL    |       |
| salary  | float(16,8)   | YES  |     | NULL    |       |
| salary2 | decimal(16,8) | YES  |     | NULL    |       |
+---------+---------------+------+-----+---------+-------+mysql> insert into t7 values(1,199992.54586,199992.54586);
Query OK, 1 row affected (0.01 sec)mysql> insert into t7 values(2,1900042.54586,1900042.54586);
Query OK, 1 row affected (0.01 sec)mysql> select * from t7;
+------+------------------+------------------+
| id   | salary           | salary2          |
+------+------------------+------------------+
|    1 |  199992.54687500 |  199992.54586000 |
|    2 | 1900042.50000000 | 1900042.54586000 |
+------+------------------+------------------+
2 rows in set (0.01 sec)

说明:float表示的精度大约是7位。
decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0.如果m被省略,默认是10。
我们可以发现decimal的精度更准确
float不管是整数部分还是小数都可能会发生数据精度丢失的情况
如果我们的应用场景需要对数据精度很高的要求推荐使用decimal类型

同样的decimal类型也会进行四舍五入操作

mysql> create table t8(-> id int,-> salary decimal(4,2)-> );
Query OK, 0 rows affected (0.01 sec)mysql> insert into t8 values(1,99.999);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t8 values(1,99.991);
Query OK, 1 row affected, 1 warning (0.00 sec)mysql> insert into t8 values(1,29.999);
Query OK, 1 row affected, 1 warning (0.00 sec)mysql> select * from t8;
+------+--------+
| id   | salary |
+------+--------+
|    1 |  99.99 |
|    1 |  30.00 |
+------+--------+
2 rows in set (0.00 sec)

3. 字符串类型

3.1 char

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

mysql> create table t9(-> id int,-> name char(2)-> );
Query OK, 0 rows affected (0.01 sec)mysql> insert into t9 values(1,'ab');
Query OK, 1 row affected (0.00 sec)mysql> insert into t9 values(2,'中国');
Query OK, 1 row affected (0.00 sec)mysql> insert into t9 values(2,'中国人');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into t9 values(1,'abc');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> select * from t9;
+------+--------+
| id   | name   |
+------+--------+
|    1 | ab     |
|    2 | 中国   |
+------+--------+
2 rows in set (0.00 sec)

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

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

这里需要提一句的是:在MySQL当中汉字也只算是一个字符,虽然在utf-8当中一个汉字占三个字节的大小

3.2 varchar

语法:

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

案例:

mysql> create table t10(-> id int,-> name varchar(6)-> );
Query OK, 0 rows affected (0.01 sec)mysql> insert into t10 values(1,'hello');
Query OK, 1 row affected (0.00 sec)mysql> insert into t10 values(1,'你好鸭!!!!');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> insert into t10 values(1,'你好鸭!!!');
Query OK, 1 row affected (0.00 sec)mysql> select * from t10;
+------+--------------------+
| id   | name               |
+------+--------------------+
|    1 | hello              |
|    1 | 你好鸭!!!         |
+------+--------------------+
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 tt11(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 BLOBsmysql> create table t11(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 t12(-> t1 date,-> t2 datetime,-> t3 timestamp-> );
Query OK, 0 rows affected (0.01 sec)mysql> insert into t12(t1,t2) values('1997-7-5','2008-8-8 12:1:1');
Query OK, 1 row affected (0.01 sec)mysql> select * from t12;
+------------+---------------------+---------------------+
| t1         | t2                  | t3                  |
+------------+---------------------+---------------------+
| 1997-07-05 | 2008-08-08 12:01:01 | 2024-03-16 19:32:24 |
+------------+---------------------+---------------------+
1 row in set (0.00 sec)mysql> update t12 set t1='2000-1-1';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0mysql> select * from t12;
+------------+---------------------+---------------------+
| t1         | t2                  | t3                  |
+------------+---------------------+---------------------+
| 2000-01-01 | 2008-08-08 12:01:01 | 2024-03-16 19:33:05 |
+------------+---------------------+---------------------+
1 row in set (0.00 sec)

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('登山','游泳','篮球','武术'),-> gender enum('男','女')-> );
Query OK, 0 rows affected (0.01 sec)

在这里插入图片描述
这里enum的存储方式就是按下标的方式存储

mysql> insert into votes values('关羽','6','3');
ERROR 1265 (01000): Data truncated for column 'gender' at row 1
mysql> insert into votes values('关羽','6','-1');
ERROR 1265 (01000): Data truncated for column 'gender' at row 1

在这里插入图片描述

# 查找出性别为女性的人
mysql> select * from votes where gender = 2;
+----------+----------------------+--------+
| username | hobby                | gender |
+----------+----------------------+--------+
| 刘备     | 篮球                 ||
| 曹操     | 游泳,篮球,武术       ||
| 孙权     | 登山,游泳,武术       ||
+----------+----------------------+--------+
3 rows in set (0.00 sec)mysql> select * from votes where gender = '女';
+----------+----------------------+--------+
| username | hobby                | gender |
+----------+----------------------+--------+
| 刘备     | 篮球                 ||
| 曹操     | 游泳,篮球,武术       ||
| 孙权     | 登山,游泳,武术       ||
+----------+----------------------+--------+
3 rows in set (0.00 sec)
# 查找出爱好中包含篮球的人
mysql> select * from votes where hobby = '篮球';
+----------+--------+--------+
| username | hobby  | gender |
+----------+--------+--------+
| 刘备     | 篮球   ||
+----------+--------+--------+
1 row in set (0.00 sec)

我们发现这样的SQL语句并不能准确的找出所有爱好中包含篮球的人,那应该如何操作呢?
集合查询使用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                         |
+---------------------------+
mysql> select 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 |
+----------+-----------------------------+--------+
| 刘备     | 篮球                        ||
| 曹操     | 游泳,篮球,武术              ||
| 孙权     | 登山,游泳,篮球,武术         ||
| 关羽     | 游泳,篮球                   ||
| 关羽     | 游泳,篮球                   |        |
+----------+-----------------------------+--------+
5 rows in set (0.00 sec)
# 查找同时爱好篮球和武术的人 --- 不能在一个find语句中同时查找两个属性
mysql> select * from votes where find_in_set('篮球',hobby) and find_in_set('武术',hobby);
+----------+-----------------------------+--------+
| username | hobby                       | gender |
+----------+-----------------------------+--------+
| 曹操     | 游泳,篮球,武术              ||
| 孙权     | 登山,游泳,篮球,武术         ||
+----------+-----------------------------+--------+
2 rows in set (0.00 sec)
# 同时拥有所有爱好的就可以用上限来查找
mysql> select * from votes where hobby = 15;
+----------+-----------------------------+--------+
| username | hobby                       | gender |
+----------+-----------------------------+--------+
| 孙权     | 登山,游泳,篮球,武术         ||
+----------+-----------------------------+--------+
1 row in set (0.01 sec)

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

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

相关文章

代码随想录算法训练营第四十八天 | 121. 买卖股票的最佳时机

好忙这几天&#xff0c;偷个懒小做一点&#xff0c;后面有空补回来 题目链接&#xff1a;121. 买卖股票的最佳时机 - 力扣&#xff08;LeetCode&#xff09; class Solution { public:int maxProfit(vector<int>& prices) {int minrINT_MAX;int result0;for(int …

前端React篇之对 Redux 的理解,主要解决什么问题?Redux 原理及工作流程

目录 对 Redux 的理解&#xff0c;主要解决什么问题&#xff1f;Redux 原理及工作流程 对 Redux 的理解&#xff0c;主要解决什么问题&#xff1f; Redux是一个用于管理数据状态和UI状态的JavaScript应用工具&#xff0c;主要解决了在复杂JavaScript单页应用&#xff08;SPA&a…

飞桨科学计算套件PaddleScience

PaddleScience 是一个基于深度学习框架 PaddlePaddle 开发的科学计算套件&#xff0c;利用深度神经网络的学习能力和 PaddlePaddle 框架的自动(高阶)微分机制&#xff0c;解决物理、化学、气象等领域的问题。支持物理机理驱动、数据驱动、数理融合三种求解方式&#xff0c;并提…

c#学习记录

1.使用可以使转义字符无效 class study {static void Main() {string a "123\t123";Console.ReadLine();Console.WriteLine(a); }} 例如&#xff1a;string a "123\t123";&#xff0c;输出123\t123 2.字符的不可变性 例如&#xff1a; class study …

Day40:安全开发-JavaEE应用SpringBoot框架JWT身份鉴权打包部署JARWAR

目录 SpringBoot-身份鉴权-JWT技术 SpringBoot-打包部署-JAR&WAR 思维导图 Java知识点 功能&#xff1a;数据库操作&#xff0c;文件操作&#xff0c;序列化数据&#xff0c;身份验证&#xff0c;框架开发&#xff0c;第三方组件使用等. 框架库&#xff1a;MyBatis&…

SQLiteC/C++接口详细介绍之sqlite3类(十三)

返回目录&#xff1a;SQLite—免费开源数据库系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍之sqlite3类&#xff08;十二&#xff09; 下一篇&#xff1a;SQLiteC/C接口详细介绍之sqlite3类&#xff08;十四&#xff09;&#xff08;未发表&#xff09; 40.sqlite3…

深入探讨医保购药APP的技术架构与设计思路

随着移动互联网的发展&#xff0c;医疗保健行业也迎来了数字化转型的浪潮。医保购药APP作为医保体系数字化的一部分&#xff0c;其技术架构和设计思路至关重要。接下来&#xff0c;小编将为您讲解医保购药APP的技术架构与设计思路&#xff0c;为相关从业者提供参考和启发。 一、…

【知识简略】 简单理解SpringCloud微服务架构:服务注册发现、配置中心、限流、熔断、降级、网关路由等

主要介绍Nacos那一套。 目录 微服务架构1.服务注册发现2.配置中心3.限流、熔断、降级4.网关路由 微服务架构 Spring Cloud 微服务架构中&#xff0c;Nacos 提供了一系列核心组件和服务治理功能&#xff0c;以下是对 Nacos 中涉及的相关组件及其功能的详细解释&#xff1a; 1.…

51单片机基础篇系列-定时/计数器的控制工作方式

&#x1f308;个人主页&#xff1a;会编程的果子君 &#x1f4ab;个人格言:“成为自己未来的主人~” 定时/计数器的控制 80C51单片机定时/计数器的工作由两个特殊功能寄存器控制&#xff0c;TMOD用于设置其工作方式&#xff1a; 1.工作方式寄存器TMOD 工作方式寄存器TMO…

Rust学习02:推荐一本入门书,免费的

都说Rust的学习曲线很陡峭&#xff0c;试过才知雀实不容易。 先说我的基础&#xff0c;非科班&#xff0c;自学Python&#xff0c;写过几个小程序。 我买书从来不扣扣嗖嗖的&#xff0c;所以先啃了几本Rust的入门书&#xff0c;包括&#xff1a; Tim McNamara的《Rust实战》&am…

inux(CentOS)/Windows-C++ 云备份项目(项目文件操作工具类设计,完成项目基本文件操作-读写-压缩-目录操作)

文章目录 1. 项目文件操作工具类设计 1. 项目文件操作工具类设计 根据前面的分析&#xff0c;这个文件类的基本属性如下&#xff1a; 文件大小信息文件最后修改时间文件最后一次访问时间&#xff0c;方便文件的热点管理文件名称&#xff0c;需要从http 请求行上的uri中获取基…

P8780 [蓝桥杯 2022 省 B] 刷题统计 Python

[蓝桥杯 2022 省 B] 刷题统计 题目描述 小明决定从下周一开始努力刷题准备蓝桥杯竞赛。他计划周一至周五每天做 a a a 道题目&#xff0c;周六和周日每天做 b b b 道题目。请你帮小明计算&#xff0c;按照计划他将在第几天实现做题数大于等于 n n n 题? 输入格式 输入一…

JavaWeb(p135-p155)

分页查询 可以利用分页插件PageHelper 1.引入依赖 <dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>1.4.2</version> </dependency>2.EmpMapper …

Python 数据结构与算法

Python 是一种强大且灵活的编程语言&#xff0c;非常适合用于实现各种数据结构和算法。数据结构和算法是计算机科学中的基础概念&#xff0c;对于解决实际问题、优化程序性能以及提高代码的可读性和可维护性至关重要。 ### 数据结构 数据结构是计算机存储、组织和管理数据的方…

Linux系统——Session ID(负载均衡如何保持会话)

目录 一、实验环境搭建 二、部署Nginx代理服务器配置 三、部署后端真是服务器Tomcat配置 四、配置Tomcat的Session ID会话保持 五、测试 此次实验是Tomcat后端服务器如何做Session ID会话保持 一、实验环境搭建 [rootlocalhost ~]#systemctl stop firewalld [rootlocalho…

一起学数据分析_3(模型建立与评估_2)

为什么要评估? 在进行数据分析时&#xff0c;尤其是在使用像sklearn这样的机器学习库建立模型后&#xff0c;模型评估的重要性不言而喻。模型评估不仅是对模型性能的一次全面检验&#xff0c;更是确保模型在实际应用中能够达到预期效果的关键步骤。 首先&#xff0c;模型评估…

iguana 库 C++ 反射原理

iguana Github : https://github.com/fananchong/iguana 官方介绍&#xff1a; universal serialization engine 虽然官方介绍是通用的序列化引擎&#xff0c;但实际上目前只支持&#xff1a; jsonyamlxml 不过&#xff0c; C 结构体/类的反射部分是通用的 通过该库&…

Linux 自动备份 mysql 脚本

这个脚本会将数据库备份为一个SQL文件&#xff0c;并将其保存在指定的目录中。 #!/bin/bash# MySQL配置 DB_USER"your_mysql_username" DB_PASS"your_mysql_password" DB_NAME"your_database_name" DB_HOST"localhost"# 备份目录 BAC…

Spring核心方法:Refresh全解(WebMVC如何装配、关联)

Spring核心方法&#xff1a;Refresh全解(WebMVC如何装配、关联) 这里是一个表格&#xff0c;列出了Spring容器刷新过程中执行的方法以及它们的作用&#xff1a; 方法名称描述prepareRefresh()初始化一些属性和状态&#xff0c;例如启动时间戳、活动标志、环境变量等。obtainF…

HTML-DAY2

HTML-DAY2 表格标签 表格的主要作用 表格主要用于显示、展示数据&#xff0c;因为它可以让数据显示的非常的规整&#xff0c;可读性非常好。特别是后台展示数据的时候&#xff0c;能够熟练运用表格就显得很重要。一个清爽简约的表格能够把繁杂的数据表现得很有条理。 Pink老…