【MySQL--04】数据类型
文章目录
- 1.数据类型
- 1.1数据类型分类
- 1.2数值类型
- 1.2.1`tinyint`类型
- 1.2.2`bit`类型
- 1.2.3小数类型
- 1.2.3.1 `float`
- 1.2.3.2 `decimal`
- 1.3字符串类型
- 1.3.1 `char`
- 1.3.2 `varchar`
- 1.3.3`char`和`varchar`的比较
- 1.4日期和时间类型
- 1.5 `enum`和`set`
- 1.5.1 `enum`
- 1.5.2 `set`
- 1.5.3 示例
1.数据类型
1.1数据类型分类
图1.1-1
1.2数值类型
图1.2-1
1.2.1tinyint
类型
数值越界测试:
mysql> create table t1 -> (id tinyint);
Query OK, 0 rows affected (0.17 sec)mysql> desc t1;
+-------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| id | tinyint(4) | YES | | NULL | |
+-------+------------+------+-----+---------+-------+
1 row in set (0.01 sec)mysql> insert into t1 values (1);
Query OK, 1 row affected (0.03 sec)mysql> insert into t1 values (128);
ERROR 1264 (22003): Out of range value for column 'id' at row 1
mysql> insert into t1 values (127);
Query OK, 1 row affected (0.05 sec)mysql> insert into t1 values (-127);
Query OK, 1 row affected (0.02 sec)mysql> insert into t1 values (-128);
Query OK, 1 row affected (0.03 sec)mysql> insert into t1 values (-129);
ERROR 1264 (22003): Out of range value for column 'id' at row 1
mysql> select * from t1;
+------+
| id |
+------+
| 1 |
| 127 |
| -127 |
| -128 |
+------+
4 rows in set (0.00 sec)
说明:
-
在
MySQL
中,整形可以指定具有符号的和无符号的,默认是有符号的。 -
可以通过
UNSIGNED
来说明某个字段是无符号的。 -
无符号案例
mysql> create table t2(id tinyint unsigned); Query OK, 0 rows affected (0.26 sec)mysql> insert into t2 values (0); Query OK, 1 row affected (0.03 sec)mysql> insert into t2 values (-1); ERROR 1264 (22003): Out of range value for column 'id' at row 1 mysql> insert into t2 values (1); Query OK, 1 row affected (0.03 sec)mysql> insert into t2 values (255); Query OK, 1 row affected (0.04 sec)mysql> insert into t2 values (256); ERROR 1264 (22003): Out of range value for column 'id' at row 1 mysql> select * from t1; +------+ | id | +------+ | 1 | | 127 | | -127 | | -128 | +------+ 4 rows in set (0.01 sec)mysql> desc t1; +-------+------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+------------+------+-----+---------+-------+ | id | tinyint(4) | YES | | NULL | | +-------+------------+------+-----+---------+-------+ 1 row in set (0.02 sec)
-
其他类型自己推导
注意:尽量不适用
unsigned
,对于int
类型可能存在放不下的数据,int unsigned
同样可以存放不下,与其如此,还不如设计时,讲int类型提升为bigint
类型。
1.2.2bit
类型
基本语法:
bit[(M)]
:位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1。
示例:
mysql> create table t3(id int,a bit(8));
Query OK, 0 rows affected (0.21 sec)mysql> desc t3;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| a | bit(8) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)mysql> insert into t3 values (1,10);
Query OK, 1 row affected (0.03 sec)mysql> select * from t3;
+------+------+
| id | a |
+------+------+
| 1 | |
+------+------+
1 row in set (0.00 sec)
发现很奇怪的现象,
a
的数据10
没有出现
bit
使用的注意事项:
bit
字段在显示时,是按照ASCII
码对应的值显示。
mysql> insert into t3 values(65,65);
Query OK, 1 row affected (0.02 sec)mysql> select * from t3;
+------+------+
| id | a |
+------+------+
| 1 | |
| 65 | A |
+------+------+
2 rows in set (0.00 sec)
- 如果我们有这样的值,只存放0或者1,这时候可以定义为bit(1)。这样可以节省空间
mysql> create table t4(-> gender bit(1));
Query OK, 0 rows affected (0.21 sec)mysql> insert into t4 values (1);
Query OK, 1 row affected (0.02 sec)mysql> insert into t4 values (0);
Query OK, 1 row affected (0.03 sec)mysql> insert into t4 values (2); --当插入2时,已经越界了
ERROR 1406 (22001): Data too long for column 'gender' at row 1
1.2.3小数类型
1.2.3.1 float
语法:
float[(m,d)] [unsigned] : M指定显示长度,d指定小数位数m,占用空间4个字节
示例:
小数:float(4,2) :表示一共最多可以有4位长度,其中小数点后两位,意味着小数点前最多2位,即数据范围为 -99.99~99.99,MySQL在保存值时会进行四舍五入.
mysql> create table t5(num float(4,2));
Query OK, 0 rows affected (0.26 sec)mysql> insert into t5 values (-99.99);
Query OK, 1 row affected (0.03 sec)mysql> insert into t5 values (99.99);
Query OK, 1 row affected (0.04 sec)mysql> insert into t5 values (99.991);
Query OK, 1 row affected (0.04 sec)mysql> select * from t5;
+--------+
| num |
+--------+
| -99.99 |
| 99.99 |
| 99.99 |
+--------+
3 rows in set (0.01 sec)mysql> insert into t5 values (99.995);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into t5 values (-99.994);
Query OK, 1 row affected (0.04 sec)mysql> select * from t5;
+--------+
| num |
+--------+
| -99.99 |
| 99.99 |
| 99.99 |
| -99.99 |
+--------+
4 rows in set (0.01 sec)
注意:当我们的
float(4,2)如果是一个有符号的,则表示范围是(-99.99,99.99),如果是无符号的,范围会变成(0,99.99)
示例:
mysql> create table t6(num float(4,2) unsigned);
Query OK, 0 rows affected (0.06 sec)mysql> insert into t6 values(0);
Query OK, 1 row affected (0.04 sec)mysql> insert into t6 values(99.99);
Query OK, 1 row affected (0.03 sec)mysql> insert into t6 values(-0);
Query OK, 1 row affected (0.03 sec)mysql> insert into t6 values(-1);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> select * from t6;
+-------+
| num |
+-------+
| 0.00 |
| 99.99 |
| 0.00 |
+-------+
3 rows in set (0.00 sec)
1.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表示的精度不一样 -- decimal精度更高更准确
mysql> create table t7(num1 float(10,8),num2 decimal(10,8)); Query OK, 0 rows affected (0.56 sec)mysql> desc t7; +-------+---------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+---------------+------+-----+---------+-------+ | num1 | float(10,8) | YES | | NULL | | | num2 | decimal(10,8) | YES | | NULL | | +-------+---------------+------+-----+---------+-------+ 2 rows in set (0.01 sec)mysql> insert into t7 values(23.12345612,23.12345612); Query OK, 1 row affected (0.04 sec)mysql> select * from t7; -- 发现decimal的精度更准确,因此我们希望数据高精度选择decimal +-------------+-------------+ | num1 | num2 | +-------------+-------------+ | 23.12345695 | 23.12345612 | +-------------+-------------+ 1 row in set (0.00 sec)
说明:
float
表示的精度大约是7位
-
-
decimal
整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0。如果m被省略,默认为10。
建议:如果希望小数的精度高,推荐使用
decimal
。
1.3字符串类型
1.3.1 char
语法:
char(L) : 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255
示例:
mysql> create table t8 (name char(2));
Query OK, 0 rows affected (0.19 sec)mysql> insert into t8 values('ab');
Query OK, 1 row affected (0.04 sec)mysql> insert into t8 values('语言');
Query OK, 1 row affected (0.03 sec)mysql> select * from t8;
+--------+
| name |
+--------+
| ab |
| 语言 |
+--------+
2 rows in set (0.00 sec)
说明:char(2)
表示可以存放两个字符,可以是字母或者汉字,但是不能超过2个。L的最大值只能是255
mysql> create table t9 (name char(256));
ERROR 1074 (42000): Column length too big for column 'name' (max = 255); use BLOB or TEXT instead
1.3.2 varchar
语法:
varchar(L) : 可变长度字符串,L表示字符长度,最大长度65535个字节
示例:
mysql> create table tt1(name varchar(6)); -- 表示可以存放6个字符
Query OK, 0 rows affected (0.23 sec)mysql> desc tt1;
+-------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| name | varchar(6) | YES | | NULL | |
+-------+------------+------+-----+---------+-------+
1 row in set (0.00 sec)mysql> insert into tt1 values ('hello');
Query OK, 1 row affected (0.04 sec)mysql> insert into tt1 values ('我爱你,祖国');
Query OK, 1 row affected (0.02 sec)mysql> insert into tt1 values ('我很爱你,祖国');
ERROR 1406 (22001): Data too long for column 'name' at row 1
mysql> select * from tt1;
+------------------+
| name |
+------------------+
| hello |
| 我爱你,祖国 |
+------------------+
2 rows in set (0.00 sec)
说明:
关于varchar(len),len到底是多大,这个len值
和表的编码密切相关:
varchar
长度可以指定为0到65535之间的值,但是有1-3个字节用于记录数据大小,所以说有效字节数是65535。- 当我们的表的编码是
utf8
时,varchar(n)的参数n的最大值为65535/3=21844(因为utf中,一个字符占3个字节)
,如果编码是gbk,varchar(n)的参数n的最大值为65536/2=32766(因为gbk一个字符占2个字节)
mysql> create table tt2(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 tt2(name varchar(21844))charset=utf8;
Query OK, 0 rows affected (0.21 sec)mysql> create table tt3(name varchar(32767))charset=gbk; -- 验证gbk确实不能超过32766
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 tt3(name varchar(32766))charset=gbk;
Query OK, 0 rows affected (0.24 sec)
1.3.3char
和varchar
的比较
实际存储 | char(4) | varcahr(4) | char 占用字节 | varchar 占用字节 |
---|---|---|---|---|
abcd | abcd | abcd | 4*3=12 | 4*3+1=13 |
A | A | A | 4*3=12 | 1*3+1=4 |
Abcde | X | X | 数据超过长度 | 数据超过长度 |
如何选择定长或变长字符串?
- 如果数据确定长度都一样,就是用定长
char
,比如:身份证,手机号等 - 如果数据长度有变化,就是用变长
varchar
,比如:名字,地址,但是你要保证最长的能存进去 - 定长的磁盘空间比较浪费,但是效率高
- 变长的磁盘空间比较节省,但是效率低
- 定长的意义是,直接开辟好对应的空间
- 变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。
1.4日期和时间类型
常用的日期有如下三个:
data :日期 'yyyy-mm-dd'
,占三个字节datetime : 时间日期格式'yyyy-mm-dd HH:ii:ss'
表示范围从1000到9999,占用8字节timestamp : 时间辍(格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数) 格式: yyyy-mm-dd HH:ii:ss 和datetime完全一致
,占用四字节。
示例:
mysql> create table tt3(t1 date,t2 datetime,d3 timestamp);
ERROR 1050 (42S01): Table 'tt3' already exists
mysql> create table tt4(t1 date,t2 datetime,d3 timestamp);
Query OK, 0 rows affected (0.17 sec)mysql> insert into tt4 (t1,t2) values('2023-04-11','1999-7-1 8:0:0');
Query OK, 1 row affected (0.03 sec)mysql> select * from tt4;
+------------+---------------------+---------------------+
| t1 | t2 | d3 |
+------------+---------------------+---------------------+
| 2023-04-11 | 1999-07-01 08:00:00 | 2023-04-11 20:58:24 |
+------------+---------------------+---------------------+
1 row in set (0.01 sec)
我们可以看到,添加数据时,时间戳自动补上当前时间。这是因为
d3
有默认值。我们可以查看一下tt4
的表结构.
mysql> desc tt4;
+-------+-----------+------+-----+-------------------+-----------------------------+
| Field | Type | Null | Key | Default | Extra |
+-------+-----------+------+-----+-------------------+-----------------------------+
| t1 | date | YES | | NULL | |
| t2 | datetime | YES | | NULL | |
| d3 | timestamp | NO | | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |
+-------+-----------+------+-----+-------------------+-----------------------------+
3 rows in set (0.01 sec)
我们如果更新
t1
的时间,表中又会有什么变化
mysql> select * from tt4;
+------------+---------------------+---------------------+
| t1 | t2 | d3 |
+------------+---------------------+---------------------+
| 2023-04-11 | 1999-07-01 08:00:00 | 2023-04-11 20:58:24 |
+------------+---------------------+---------------------+
1 row in set (0.01 sec)
mysql> update tt4 set t1='2000-1-1';
Query OK, 1 row affected (0.03 sec)
Rows matched: 1 Changed: 1 Warnings: 0mysql> select * from tt4;
+------------+---------------------+---------------------+
| t1 | t2 | d3 |
+------------+---------------------+---------------------+
| 2000-01-01 | 1999-07-01 08:00:00 | 2023-04-11 21:00:44 |
+------------+---------------------+---------------------+
1 row in set (0.00 sec)
我们发现,更新数据时,时间戳会更新成当前时间。
1.5 enum
和set
1.5.1 enum
语法:
enum
:枚举,单选类型
enum('选项1','选项2','选项3'.....);
该设定值只是提供了若干个选项的值,最终一个单元格中,实际值存储了其中一个值,而是处于效率考虑,这些值实际存储的是 数字,因为这些选项的每个选项值一次对应如下数字:1,2,3,.....最多65535个
,当我们添加枚举值时,也可以添加对应的数字编号。
1.5.2 set
语法:
set
:集合,多选类型
set('选项值1','选项值2','选项值3',......);
该设定值只是提供了若干个选项的值,最终一个单元格中,设计可以存储了其中任意多个值,而且处于效率考虑,这些值实际存储的是 位图数字
,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32.....
最多64个
示例:set('选项1','选项2','选项3','选项4','选项5');
选项1 | 选项2 | 选项3 | 选项4 | 选项5 |
---|---|---|---|---|
00001 | 00010 | 00100 | 01000 | 10000 |
因此如果你要同时选择选项1和选项2
可以输入3 因为00001 + 00010 = 00011
对应的10进制数字3
说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读
1.5.3 示例
示例:
有一个调查表votes
,需要调查人的喜好,比如(登山,游泳,篮球,武术)中去选择(可以多选),性别(男,女)[单选]
mysql> create table votes(
name varchar(20),
gender enum('男','女'),
hobby set('登山','游泳','篮球','武术')
);
Query OK, 0 rows affected (0.21 sec)
mysql> desc votes;
+--------+------------------------------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+------------------------------------------+------+-----+---------+-------+
| name | varchar(20) | YES | | NULL | |
| gender | enum('男','女') | YES | | NULL | |
| hobby | set('登山','游泳','篮球','武术') | YES | | NULL | |
+--------+------------------------------------------+------+-----+---------+-------+
3 rows in set (0.02 sec)
插入数据:
mysql> insert into votes values('张三','男','登山');
Query OK, 1 row affected (0.05 sec)mysql> insert into votes values('李四','1','登山,篮球');
Query OK, 1 row affected (0.02 sec)mysql> insert into votes values('王五','2','7');
Query OK, 1 row affected (0.02 sec)mysql> insert into votes values('赵六','2','15');
Query OK, 1 row affected (0.04 sec)mysql> select * from votes;
+--------+--------+-----------------------------+
| name | gender | hobby |
+--------+--------+-----------------------------+
| 张三 | 男 | 登山 |
| 李四 | 男 | 登山,篮球 |
| 王五 | 女 | 登山,游泳,篮球 |
| 赵六 | 女 | 登山,游泳,篮球,武术 |
+--------+--------+-----------------------------+
4 rows in set (0.00 sec)
如表中数据,想要查找所有喜欢登山的人:
mysql> select * from votes;
+--------+--------+-----------------------------+
| name | gender | hobby |
+--------+--------+-----------------------------+
| 张三 | 男 | 登山 |
| 李四 | 男 | 登山,篮球 |
| 王五 | 女 | 登山,游泳,篮球 |
| 赵六 | 女 | 登山,游泳,篮球,武术 |
+--------+--------+-----------------------------+
4 rows in set (0.00 sec)mysql> select * from votes where hobby = '登山';
+--------+--------+--------+
| name | gender | hobby |
+--------+--------+--------+
| 张三 | 男 | 登山 |
+--------+--------+--------+
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('d','a,b,c');
+--------------------------+
| find_in_set('d','a,b,c') |
+--------------------------+
| 0 |
+--------------------------+
1 row in set (0.00 sec)
因此查询爱好登山的人
mysql> select * from votes where find_in_set('登山',hobby);
+--------+--------+-----------------------------+
| name | gender | hobby |
+--------+--------+-----------------------------+
| 张三 | 男 | 登山 |
| 李四 | 男 | 登山,篮球 |
| 王五 | 女 | 登山,游泳,篮球 |
| 赵六 | 女 | 登山,游泳,篮球,武术 |
+--------+--------+-----------------------------+
4 rows in set (0.00 sec)
查询同时爱好登山和游泳的人
mysql> select * from votes where find_in_set('登山',hobby) and find_in_set('游泳',hobby);
+--------+--------+-----------------------------+
| name | gender | hobby |
+--------+--------+-----------------------------+
| 王五 | 女 | 登山,游泳,篮球 |
| 赵六 | 女 | 登山,游泳,篮球,武术 |
+--------+--------+-----------------------------+
2 rows in set (0.00 sec)
(本篇完)
相关文章:

【MySQL--04】数据类型
文章目录1.数据类型1.1数据类型分类1.2数值类型1.2.1tinyint类型1.2.2bit类型1.2.3小数类型1.2.3.1 float1.2.3.2 decimal1.3字符串类型1.3.1 char1.3.2 varchar1.3.3char和varchar的比较1.4日期和时间类型1.5 enum和set1.5.1 enum1.5.2 set1.5.3 示例1.数据类型 1.1数据类型分…...

git 将其它分支的文件检出到工作区
主要是使用如下命令: git checkout [-f|--ours|--theirs|-m|--conflict<style>] [<tree-ish>] [--] <pathspec>…覆盖与 pathspec 匹配的文件的内容。当没有给出<tree-ish> (通常是一个commit)时,用 index 中的内容覆盖工作树…...

人工智能的最大危险是什么?
作者:GPT(AI智学习) 链接:https://www.zhihu.com/question/592107303/answer/2966857095 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 首先:人工智能为人类带来了很多益处&…...

rk3568点亮E-ink
rk3568 Android11/12 适配 E-ink “EINK”是英语ElectronicInk的缩写。翻译成中文为“电子墨水”。电子墨水由数百万个微胶囊(Microcapsules)所构成,微胶囊的大小约等同于人类头发的直径。每个微胶囊里含有电泳粒子──带负电荷的白色以及带正电荷的黑色粒子&#…...

如何将Springboot项目通过IDEA打包成jar包,并且转换成可执行文件
首先在IDEA打开你的项目,需要确认项目可以正常运行,然后点击页面右侧的Maven,运行Lifecycle下的package, 此时在项目的target目录下就可以看到一个jar包 这个时候你可以在jar包所在目录下执行cmd窗口,运行 java -jar campus-market-0.0.1-S…...

总结:网卡
一、背景 经常听到eth0,bond0这些概念,好奇他们的区别,于是有了此篇文章记录下。 二、介绍 网卡:即网络接口板,又称网络适配器或NIC (网络接口控制器),是一块被设计用来允许计算机在计算机网络上进行通讯…...

Java这么卷,还有前景吗?
“Java很卷”、“大家不要再卷Java了”,经常听到同学这样抱怨。但同时,Java的高薪也在吸引越来越多的同学。不少同学开始疑惑:既然Java这么卷,还值得我入行吗? 首先先给你吃一颗定心丸:现在选择Java依然有…...

后端简易定时任务框架选择(Python/Go)--gocron
文章目录前言实现后语前言 在使用Python的web框架中,包括flask/Django,其中大量用到celery;celery作为异步任务使用的多,同时也会用celery来跑些定时任务,比如每晚定时跑脚本、跑数据统计等闲时任务。但随着任务量的增…...

【GStreamer学习】之GStreamer基础教程
目标 没有什么比在屏幕上打印出“Hello World”更能获得对软件库的第一印象了! 但是由于我们正在学习多媒体框架,所以我们将输出“Hello World!”改为播放视频。 不要被下面的代码量吓到:只有 4 行是真正需要的, 其…...

各类Round-Robin总结,含Verilog实现
1. Fixed Priority Arbitrary 固定优先级就是指每个req的优先级是不变的,即优先级高的先被处理,优先级低的必须是在没有更高优先级的req的时候才会被处理。所以转化为数学模型就是找出req序列中第一个为1的位置,然后将其转换为onehot。 例如: req[3:0] = 4b1100 ==> g…...

《软件设计师-知识点》
1、指令流水线 (一)一条指令的执行过程可分为三个阶段:取指、分析、执行。 取指:根据PC(程序计数器)内容访问主存储器,取出一条指令送到IR(指令寄存器)中。 分析&…...

mysql 同义词_数据库中的同义词synonym
一、Oracle数据只有一个实例(简单理解就是Oracle 只能建立一个数据库,不像MySQL,它下面可以创建N个库),那么Oracle是根据用户灵活去管理的;这点读起来、理解 起来也不那么难,但是除非自己亲自实现一把才理解深入点&…...

Nacos共享配置
本文介绍一下Nacos作为配置中心时,如何读取共享配置 我的环境 Windows10JDK8SpringCloud:Finchley.RELEASESpringBoot:2.0.4.RELEASEspring-cloud-alibaba-dependencies:0.2.2.RELEASENacos-server:1.0.1 本文的项目…...

数据结构——排序(4)
作者:几冬雪来 时间:2023年4月12日 内容:数据结构排序内容讲解 目录 前言: 1.快速排序中的递归: 2.小区间优化: 3.递归改非递归: 4.归并排序: 5.归并排序的非递归形式&…...

C++13:搜索二叉树
目录 搜索二叉树概念 模拟实现搜索二叉树 插入函数实现 插入函数实现(递归) 查找函数实现 删除函数实现 删除函数实现(递归) 中序遍历实现 拷贝构造函数实现 析构函数实现 赋值重载 我们在最开始学习二叉树的时候,…...

【从零开始学Skynet】基础篇(五):简易聊天室
在游戏中各玩家之间都可以进行聊天之类的交互,在这一篇中,我们就来实现一个简易的聊天室功能,这在上一篇代码的基础上很容易就能实现。1、功能需求 客户端发送一条消息,经由服务端转发,所有在线客户端都能收到…...

HDU - 2089 不要62(数位DP)
题目如下: 杭州人称那些傻乎乎粘嗒嗒的人为 626262(音:laoer)。 杭州交通管理局经常会扩充一些的士车牌照,新近出来一个好消息,以后上牌照,不再含有不吉利的数字了,这样一来&#x…...

网络安全与防御
1. 什么是IDS? IDS(入侵检测系统):入侵检测是防火墙的合理补充,帮助系统对付网络攻击,扩展了系统管理员的安全管理能力,提高了信息安全基础结构的完整性。主要针对防火墙涉及不到的部分进行检测。 入侵检测主要面对的…...

【DT】蒸脱机的结构和工作原理
DT蒸脱机的结构和工作原理什么是DTDT结构图工作过程什么是DT DT 蒸脱机(DesolventazationerToaster),根据英文名可以看出来,他的作用是脱溶、烘烤。用于蒸脱湿豆粕中的溶剂。 大豆油生产工艺有2种:压榨油的加工工艺是…...

Docker管理软件
下面是一些常见的Docker管理软件 Portainer Portainer是一个轻量级的Docker管理界面,可以以用户友好的方式显示Docker环境的状态。它提供了仪表板、容器、镜像、卷、网络等功能。 Rancher Rancher是一个开源的Docker容器管理平台,支持多个主机和集群…...

关于运行时内存数据区的一些扩展概念
栈顶缓存技术(Top-of-Stack Cashing) 前面提过,基于栈式架构的虚拟机所使用的零地址指令更加紧凑,但完成一项操作的时候必然需要使用更多的入栈和出栈指令,这同时也就意味着将需要更多的指令分派(instruction dispatc…...

计算机组成原理第二章数据的表示与运算(中)
提示:且行且忘且随风,且行且看且从容 文章目录前言2.2.0 奇偶校验码(大纲已删)2.2.1 电路的基本原理 加法器设计2.2.2 并行进位加法器2.2.3 补码加减运算器2.2.4 标志位的生成2.2.5 定点数的移位运算2.2.62.2.6.1 原码的乘法运算2.2.6.2 补码的乘法运算2…...

我的第一台电脑的故事
第一台电脑啊,多么遥远的故事了,又似乎就在眼前。今天重回往事,就简单记录一下吧。 🌱缘起 那是初一,至今已13年,遂觉遥远,而又是立志我学习的起点,至今还在校园,又觉就…...

【1041. 困于环中的机器人】
来源:力扣(LeetCode) 描述: 在无限的平面上,机器人最初位于 (0, 0) 处,面朝北方。注意: 北方向 是 y 轴的正方向。南方向 是 y 轴的负方向。东方向 是 x 轴的正方向。西方向 是 x 轴的负方向。 机器人可…...

几何算法——4.交线(intersection curve)的表达与参数化、微分性质
几何算法——4.曲面求交的交线(intersection curve)的表达与参数化、微分性质1 关于曲面求交的交线表达2 交线的微分性质3 交线的参数化4 修正弦长参数化的微分性质1 关于曲面求交的交线表达 两个曲面求交,比较经典的方法是用跟踪法…...

【GPT】让你事半功倍特别好用的5个GPT工具
文章目录前言一、现在还能开通ChatGPT4.0吗?二、推荐五款与ChatGPT的相关实用工具1.一款浏览器插件:ChatGPT for Google2.一款生成图片的AI工具:midjourney3.推荐两款AI自动生成PPT:闪击PPT、mindshow4.识别PFD文件内容对话&#…...

人工智能大模型多场景应用原理解析
前言 在上篇文章《人工智能大模型之ChatGPT原理解析》中分享了一些大模型之ChatGPT的核心原理后,收到大量读者的反馈,诸如:在了解了核心原理后想进一步了解未来的发展趋势(比如生成式人工智能和元宇宙能擦出什么样的火花?),大模型…...

SpringBoot默认包扫描机制与默认配置文件
文章目录一、SpringBoot默认包扫描机制 - 示例二、SpringBoot默认扫描包机制 - 原理三、SpringBoot手动扫描包机制 - 原理&示例四、ComponentScan与MapperScan五、SpringBoot默认配置文件一、SpringBoot默认包扫描机制 - 示例 默认情况下,扫描启动类同级及其子…...

RabbitMq 消息可靠性问题(一) --- publisher发送时丢失
前言 消息从生产者发送到exchange, 再到 queue, 再到消费者。这个过程中有哪些有消息丢失的可能性呢? 发送时丢失: 生产者发送的消息未送达 exchange消息到达 exchange 后未到达 queue MQ 宕机,queue将消息丢失consumer 接收到消息后未消费…...

Java初识泛型
目录 一、包装类 1、基本数据类型和对应的包装类 2、装箱和拆箱 3、自动装箱和自动拆箱 二、什么是泛型 三、引出泛型 1、泛型的语法 四、泛型类的使用 1、语法 2、示例 3、类型推导(Type Inference) 六、泛型如何编译的 1、擦除机制 2、为什么不能实例化泛型类…...