首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

面试官:如果要ip地址,什么数据类型比较好

在看高性能MySQL第3版(4.1.7节)时,作者建议当存储IPv4地址时,应该使用32位的无符号整数(UNSIGNED INT)来存储IP地址,而不是使用字符串。但是没有给出具体原因。...MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数INET_ATON,以及把整数格式的IP转换成字符串的INET_NTOA。...如下所示: mysql> select inet_aton('192.168.0.1'); +--------------------------+ | inet_aton('192.168.0.1')...对于转换字符串IPv4和数值类型,可以放在应用层 下面是使用java代码来对二者转换: package com.mikan; /** * @author Mikan */ public class

98830

面试官:如果要ip地址,什么数据类型比较好?

导读:设计表结构存储IPV4地址时,你的第一反应是什么类型?...在看高性能MySQL第3版(4.1.7节)时,作者建议当存储IPv4地址时,应该使用32位的无符号整数(UNSIGNED INT)来存储IP地址,而不是使用字符串。 但是没有给出具体原因。...MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...: 不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数INET_ATON,以及把整数格式的IP转换成字符串的INET_NTOA。...对于转换字符串IPv4和数值类型,可以放在应用层,下面是使用java代码来对二者转换: package com.mikan; /** * @author Mikan */ public class

1.1K30
您找到你想要的搜索结果了吗?
是的
没有找到

2021-01-06:mysql中,我十亿个手机号码...

需要手机号列唯一约束吗? 最简单情况(中国手机号,11位数字)就用数值类型bigint存储即可,建索引。...考虑三种类型,BigInt,Char,Varchar 这几种类型在 InnoDB 引擎下默认行格式的存储方式为: 1.对于 bigint 类型,如果不为 NULL,则占用8字节,首位为符号位,剩余位存储数字...2.对于定长字段,不需要长度信息直接存储数据即可,如果不足设定的长度则补充。对于 char 类型,补充 0x20, 对应的就是空格。...由于手机号不更新,并且不同国家的手机号长度不同,并且可能有特殊字符,字符类型在默认的编码和排序规则下进行范围匹配也能满足我们的需求,所以为了节省空间,使用 varchar 类型。...这样查询某个手机号是否存在这种业务就能更快,因为一张表被划分成了很多张小表。并且如果涉及多张小表 MySQL 还可以多线程并发查,效率提升很多。

90010

面试官:如果要 IP 地址,什么数据类型比较好?

在看高性能MySQL第3版(4.1.7节)时,作者建议当存储IPv4地址时,应该使用32位的无符号整数(UNSIGNED INT)来存储IP地址,而不是使用字符串。但是没有给出具体原因。...MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...: 不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数INET_ATON,以及把整数格式的IP转换成字符串的INET_NTOA。...如下所示: mysql> select inet_aton('192.168.0.1'); +--------------------------+ | inet_aton('192.168.0.1')...对于转换字符串IPv4和数值类型,可以放在应用层,下面是使用java代码来对二者转换: package com.mikan; /** * @author Mikan */ public class

95220

面试官:如果要ip地址,什么数据类型比较好

MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...“https://bafford.com/2009/03/09/mysql-performance-benefits-of-storing-integer-ip-addresses/ 使用无符号整数来存储也有缺点...: 不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数INET_ATON,以及把整数格式的IP转换成字符串的INET_NTOA。...如下所示: mysql> select inet_aton('192.168.0.1'); +--------------------------+ | inet_aton('192.168.0.1')...对于转换字符串IPv4和数值类型,可以放在应用层,下面是使用java代码来对二者转换: package com.mikan; /**  * @author Mikan  */ public class

26120

面试官:如果要 ip 地址,什么数据类型比较好?

来源:blog.csdn.net/mhmyqn/article/details/48653157 在看高性能MySQL第3版(4.1.7节)时,作者建议当存储IPv4地址时,应该使用32位的无符号整数(...MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...: 不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数INET_ATON,以及把整数格式的IP转换成字符串的INET_NTOA。...如下所示: mysql> select inet_aton('192.168.0.1'); +--------------------------+ | inet_aton('192.168.0.1')...对于转换字符串IPv4和数值类型,可以放在应用层,下面是使用java代码来对二者转换: package com.mikan; /** * @author Mikan */ public class

81240

面试官:如果要ip地址,什么数据类型比较好

来源:blog.csdn.net/mhmyqn/article/details/48653157 在看高性能MySQL第3版(4.1.7节)时,作者建议当存储IPv4地址时,应该使用32位的无符号整数...MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...: 不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数INET_ATON,以及把整数格式的IP转换成字符串的INET_NTOA。...如下所示: mysql> select inet_aton('192.168.0.1'); +--------------------------+ | inet_aton('192.168.0.1')...对于转换字符串IPv4和数值类型,可以放在应用层,下面是使用java代码来对二者转换: package com.mikan; /** * @author Mikan */ public class

29610

mysql存储手机号什么不用bigint?

因此,为什么不使用bigint存储手机号呢? 手机号一般是要加索引的吧。。bigint你用了like索引就失效了 1.首先,手机号的本质是字符串而不是数字,只是恰巧长得像数字而已。...5.手机号可能有-(座机),int不了。...; 更高的操作效率(待验证); 支持更多的操作,比如between and操作; VARCHAR的优势: 灵活;设计时候可以指定最大长度,存储时,多少占用多少; CHAR的优势: 效率比varchar...,交给数字类型比较好,所有才会有这样的想法,int对比varchar总该有性能提升吧;当然这样做,也有局限性: 实现起来变麻烦了,不过对于13亿数据量来说本身就应该分表了,一张表200w数据后就可能操作起来显著变慢...那int实现的扩展性将是致命的; 分析下来,int或许有些许性能优势,但其带来的复杂度和扩展上的劣势让我根本都不必动手,就打消了念头了;唉,也许这就是为什么大多数公司选择varchar存储手机号的原因吧

3.2K20

如果要 IP 地址,什么数据类型比较好?大部人都会答错!

来源:blog.csdn.net/mhmyqn/article/details/48653157 在看高性能MySQL第3版(4.1.7节)时,作者建议当存储IPv4地址时,应该使用32位的无符号整数(...MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...: 不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数INET_ATON,以及把整数格式的IP转换成字符串的INET_NTOA。...如下所示: mysql> select inet_aton('192.168.0.1'); +--------------------------+ | inet_aton('192.168.0.1')...对于转换字符串IPv4和数值类型,可以放在应用层,下面是使用java代码来对二者转换: package com.mikan; /** * @author Mikan */ public class

42430

如果要 IP 地址,什么数据类型比较好?大部人都会答错!

来源:blog.csdn.net/mhmyqn/article/details/48653157 在看高性能MySQL第3版(4.1.7节)时,作者建议 当存储IPv4地址时,应该使用32位的无符号整数...MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...: 不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数 INET_ATON,以及把整数格式的IP转换成字符串的 INET_NTOA。...如下所示: mysql> select inet_aton('192.168.0.1'); +--------------------------+ | inet_aton('192.168.0.1')...对于转换字符串IPv4和数值类型,可以放在应用层,下面是使用java代码来对二者转换: 推荐阅读:看看人家 SpringBoot + vue后台管理系统,多么优雅... package com.mikan

56820

面试官:如果要 IP 地址,什么数据类型比较好?99%人都会答错!

MySQL在保存变长的字符串时,还需要额外的一个字节来保存此字符串的长度。而如果使用无符号整数来存储,只需要4个字节即可。...https://bafford.com/2009/03/09/mysql-performance-benefits-of-storing-integer-ip-addresses/ 使用无符号整数来存储也有缺点...: 不便于阅读 需要手动转换 对于转换来说,MySQL提供了相应的函数来把字符串格式的IP转换成整数INET_ATON,以及把整数格式的IP转换成字符串的INET_NTOA。...如下所示: mysql> select inet_aton('192.168.0.1'); +--------------------------+ | inet_aton('192.168.0.1')...对于转换字符串IPv4和数值类型,可以放在应用层,下面是使用java代码来对二者转换: package com.mikan; /**  * @author Mikan  */ public class

28621

mysql中的enum是什么类型_数据库枚举类型什么

什么使用枚举 限定值的取值范围,比如性别(男,女,未知)等。...枚举类型使用陷阱 超级不推荐在mysql中设置某一字段类型为enum,但是的值为数字,比如‘0’,‘1’,‘2’; 解释1:你会混淆,因为enum可以通过角标取值,但它的角标是从1开始,对于不熟悉这个字段的人这里会出错...解释2:enum类型的字段对于0与‘0’有非常大的区别,如果你是0当角标做操作,因它没有这个角标,所要会报错;如果你使用‘0’这个值去取枚举值,并做插入操作,你会发现它竟然会成功,但是插入的结果是一个...不要拿mysql的enum类型一些数字;如果你一定要使用这个字段去数字,请把这个字段定义为int,然后在java代码中使用枚举类做一个对于这个字段值范围的一个限定!...; * Mysql中枚举类型Color定义取值的顺序是RED、GREEN、BLUE,因此,当这三个取值持久化到数据库表时,取值分别是0、1、2; * 意思就是我们这里往数据库的数据是

4.2K20

MySQL的MVCC是什么,有什么

MySQL的MVCC是什么,有什么? 一、介绍 面试被问到了MVCC,我不知道啊,一脸懵逼!...在MySQL中,这样大幅度提高了InnoDB的并发度。在内部实现中,InnoDB通过undo log保存每条数据的多个版本,并且能够找回数据历史版本提供给用户读,每个事务读到的数据版本可能是不一样的。...快照读配合当前读会影响,读取的结果,我们看下面的undo log和readView 我们要确定版本时,就是拿着快照读去匹配版本链上的每一个undo log,从最后往前进行判断 使用这些判断条件,MySQL...---- 那么为什么说可重复读RR,并不能完全解决幻读的问题呢? 因为,在同一个事务中,快照读是复用的,一旦事务中出现了一次当前读,也就是执行了update等语句,那么就会重新刷新快照读。...但同一个事务中,如果是因为自己修改了数据,从而导致两次查询结果不一致的情况,这是正常现象,不叫不可重复读 这也正是,为什么发生当前读后,快照读要重新进行生成的原因。

14520

mysql数据库double类型_timestamp是什么数据类型

1、整型 MySQL数据类型 含义(有符号) tinyint(m) 1个字节 范围(-128~127) smallint(m) 2个字节 范围(-32768~32767) mediumint(m)...int(m)里的m是表示SELECT查询结果集中的显示宽度,并不影响实际的取值范围,没有影响到显示的宽度,不知道这个m有什么。...2、浮点型(float和double) MySQL数据类型 含义 float(m,d) 单精度浮点型 8位精度(4字节) m总个数,d小数位 double(m,d) 双精度浮点型 16...位精度(8字节) m总个数,d小数位 设一个字段定义为float(5,3),如果插入一个数123.45678,实际数据库里的是123.457,但总个数还以实际为准,即6位。...6.日期时间类型 MySQL数据类型 含义 date 日期 ‘2008-12-2’ time 时间 ’12:25:36′ datetime 日期时间 ‘2008-12-2 22:06:44’ timestamp

2.5K20

dat文件什么软件打开?它是什么类型的文件?

我们知道电脑有专门的运用统,不管是文件、音频一些手机上不能打开的都能在电脑打开,电脑上关于文件的格式也有很多种,很多人不知道dat文件格式是什么。接下来就跟小编一起来看看dat文件什么软件打开?...它是什么类型的文件? image.png 一、dat是什类型的文件? 首先我们要清楚dat是一种什么格式的文件,dat有两种格式,一种是纯文本的文件,另一种是多媒体的影像文件。...二、dat文件什么软件打开 1、如果dat文件是多媒体软件 如果dat文件是音频软件时,我们可以先用电脑自带的播放软件进行播放。...关于dat文件什么软件打开?它是什么类型的文件这两个问题,小编就回答到这里,相信你们看了都有一定的了解。...如果还对dat文件什么软件打开这个问题有疑惑的,可以咨询相关的专业人员,在生活中我们的电脑出现问题时,也要及时咨询尽快解决问题。

7.7K30

MySql学习笔记(一)- 表类型有哪些,怎么

天天在用mysql,你说sql有什么学的,但是面试官说你学的都是皮毛。怎么样?...要说的就是mysql的一些比较重要的东西,也是对自己学习的一种挖掘。所以,说的不对的地方还望大家指正。...我们都知道数据库是一个数据树,就是将数据树的结构存储,就二叉树来说可以筛选50%的数据,所以树同一节点的分支愈多则树的深度就会越少,树深越小的话检索的速度就能提升上去,毕竟B树的检索瓶颈往往位于读磁盘上...mysql的基本表类型有MyISAM、InnoDB、DBD、MEMORY、MERGE、EXAMPLE、NDB CLUSTER、ARCHIVE、CSV、BLACKHOLE、FEDERATED等。...如果创建表的时候不指定表类型,默认为InnoDB,这是mysql5.5之后约定的规范。当然您可以通过修改ini文件来指定默认的表类型。 ?

2.3K30
领券