ipv4转成int存储
㈠ C语言中,IPv4和IPv6地址用什么数据格式存储
ipv4中的ip地址长度才为32位 ,实际上还会包含报头、版本号、记录上层信息的数据结构等等。不是一个数据类型就可以表示的,都是采用结构体的形式。
有兴趣可以看看Tcp_ip协议(共3卷)。
㈡ 什么是存储在sql服务器的IP地址最合适的数据类型
1. 存储一个IPv4地址作为binary(4)是最真实的,以究竟意味着什么,并且可以很容易面罩式的查询。但是,它需要转换和退出,如果你的文本后表示,实际上。在这种情况下,您可能更喜欢一个字符串格式。 一个SQL Server的函数 CodeGo.net,可以帮助如果你是存储为一个字符串是PARSENAME顺便提一下。不是专为IP地址,但完全适合他们。下面的调用将返回'14':SELECT PARSENAME('123.234.23.14', 1)
(编号为从右到左)。
2. 我通常为varchar(15),用于IPv4地址-但它们排序是一种痛苦,除非你垫零。 我还保存它们作为过去的诠释。System.Net.IPAddress有GetAddressBytes方法,该方法将返回的IP地址为4字节表示的IP地址的数组。你下面的C#代码的转换IPAddress到int...var ipAsInt = BitConverter.ToInt32(ip.GetAddressBytes(), 0);
我,我不得不做了很多寻找重复数据删除的地址,并希望该指标是小&越快越好。然后拉地址背出的int和成IPAddressNET中的对象,请使用GetBytes在方法BitConverter得到int作为一个字节数组。通过该字节数组的构造函数IPAddress这需要一个字节数组,你最终备份与IPAddress您开始使用。var myIp = new IPAddress(BitConverter.GetBytes(ipAsInt));
3. 对于这个在接受的答案 它们排序是一种痛苦,除非你垫 零。 下面是SQL Server 2008的一个把戏(从伊茨克奔甘在这本书)with ip_addresses as
(
SELECT '131.33.2.201' AS ip_address UNION ALL
SELECT '2.12.4.4' AS ip_address UNION ALL
SELECT '131.33.2.202' AS ip_address UNION ALL
SELECT '2.12.4.169' AS ip_address UNION ALL
SELECT '131.107.2.201' AS ip_address
)
select ip_address
from ip_addresses
ORDER BY CAST('/' + ip_address + '/' AS hierarchyid)
回报ip_address
-------------
2.12.4.4
2.12.4.169
131.33.2.201
131.33.2.202
131.107.2.201
4. 我最喜欢的文章谈到为什么你不该'正则表达式来解析IP地址。大多数他们正在谈论的是真正解释为什么你应该非常小心的IP地址的文本表示。我建议你决定什么数据类型在数据库中之前读它,大概也因为种种处理您的应用程序会做(即使文章是写关于Perl,它的任何语言)。 我想在年底的32位数据类型(或4个8位数据类型)将是最好的选择。
5. 我在这里读了很多类似的问题,并没有在这个在别人的头号答案的答复:“对于IPv4地址,您可能希望将它们保存为一个无符号整型的INET_ATON()和INET_NTOA()函数返回其值的IP地址,反之亦然“。我想这就是我要在我的分贝走,除非我在上面决定。
6. 最好的方法(当不需要排序和对IP的其他控制)是其存储为整数,将其存储为varchar等将花费不仅仅是一个简单的无辜整型的方式更多的性能。 有一个属性IPAddress.Address但它是过时的,我也不知道为什么,因为如果你不需要排序或通过IP类控制,最好的办法是将其存储为无符号整数(即有一个最大值0xffffffff它等于255.255.255.255在十进制表示。 也IPAddress类有一个接受长期的构造 并根据VS调试器可视化工具,即IPAddress类本身存储它的内部变量作为一个数字(而不是字节数组)。 了解更多关于存储的解决方法在MS SQL Server的单位: 在MS SQL 4字节无符号整型? SQL Server的4字节无符号整型
7. IPV4? INT?或TINYINT×4? 这真的取决于它是否只是存储和检索或如果它的将是一个远程的搜索条件。
8. 不要忘了IPv6的-你需要更多的房间,如果你需要存储它们-128为IPv4的32。 我会去的bigint,但你需要帮手的代码翻译到人类友好的版本。
9. 对于空间高效的存储和当值是要被处理(匹配的范围),一个int。 IP地址真的只是一个32位的值。 对于一个简单的解决方案,你只是要存储的值来查看它,一varchar(15)存储IP地址的字符串表示表单。
10. 我可能会用一个去varchar或char。 和大小设置为15。
11. PHP,然后PHP5有2个内置的转换函数: ip2long和long2ip(或)它返回/转换有符号整数
12. 我已经受够了进行四SMALLINT(或其他短小的整数数据类型,你喜欢)列-每个八位位组。然后,你可以做一个视图,它摔破在一起作为一个char字符串(显示)或则你可以写简单的运算符来决定谁都是在等什么 这是相当快的(只要你做正确的索引),并且还允许很容易查询(没有字符串操作!)。
13. 由于IP地址有32位,它可以你很长的保存价值? 它不会是因为空间浪费VARCHAR,但随后你会收到将其解码回一个IP,每一个和时延和开销成本可能不值得。
14. 引用这样的: 在CHAR存储IP地址(15)柱。这取决于有多少数据要存储,这可能是非常浪费的(为什么我们需要存储的点?)
㈢ 关于mysql数据库里面数据类型number的问题
MySQL 数据类型细分下来,大概有以下几类:
数值,典型代表为 tinyint,int,bigint
浮点/定点,典型代表为 float,double,decimal 以及相关的同义词
字符串,典型代表为 char,varchar
时间日期,典型代表为 date,datetime,time,timestamp
二进制,典型代表为 binary,varbinary
位类型
枚举类型
集合类型
大对象,比如 text,blob
json 文档类型
一、数值类型(不是数据类型,别看错了)如果用来存放整数,根据范围的不同,选择不同的类型。
注意:timestamp 代表的时间戳是一个 int32 存储的整数,取值范围为 '1970-01-01 00:00:01.000000' 到 '2038-01-19 03:14:07.999999';datetime 取值范围为 '1000-01-01 00:00:00.000000' 到 '9999-12-31 23:59:59.999999'。
1. 如果时间有可能超过时间戳范围,优先选择 datetime。2. 如果需要单独获取年份值,比如按照年来分区,按照年来检索等,最好在表中添加一个 year 类型来参与。3. 如果需要单独获取日期或者时间,最好是单独存放,而不是简单的用 datetime 或者 timestamp。后面检索时,再加函数过滤,以免后期增加 SQL 编写带来额外消耗。
建立表 t5,对这些可能需要的字段全部分离开,这样以后写 SQL 语句的时候就很容易了。
当然了,这种情形占用额外的磁盘空间。如果想在易用性与空间占用量大这两点来折中,可以用 MySQL 的虚拟列来实时计算。比如假设 c5 字段不存在,想要得到 c5 的结果。mysql-(ytt/3305)->alter table t5 drop c5, add c5 year generated always as (year(c1)) virtual;Query OK, 1 row affected (2.46 sec)Records: 1 Duplicates: 0 Warnings: 0
五、二进制类型
binary(10)/varbinary(10) 代表的不是字符个数,而是字节数。
行结束符不一样。char 的行结束符是 ,binary 的行结束符是 0x00。
由于是二进制存储,所以字符编码以及排序规则这类就直接无效了。
六、位类型
1. 对于 bit(8) 如果单纯存放 1 位,左边以 0 填充 00000001。2. 查询时可以直接十进制来过滤数据。3. 如果此字段加上索引,MySQL 不会自己做类型转换,只能用二进制来过滤。
创建表 c1, 字段性别定义一个比特位。mysql-(ytt/3305)->create table c1(gender bit(1));Query OK, 0 rows affected (0.02 sec)
mysql-(ytt/3305)->select cast(gender as unsigned) 'f1' from c1;+------+| f1 |+------+| 0 || 1 |+------+2 rows in set (0.00 sec)
过滤数据也一样,二进制或者直接十进制都行。mysql-(ytt/3305)->select conv(gender,16,10) as gender -> from c1 where gender = b'1';+--------+| gender |+--------+| 1|+--------+1 row in set (0.00 sec)mysql-(ytt/3305)->select conv(gender,16,10) as gender -> from c1 where gender = '1';+--------+| gender |+--------+| 1|+--------+1 row in set (0.00 sec)
mysql-(ytt/3305)->create table c2(gender char(0));Query OK, 0 rows affected (0.03 sec)
mysql-(ytt/3305)->select count(*) from c1;+----------+| count(*) |+----------+| 33554432 |+----------+1 row in set (1.37 sec)
mysql-(ytt/3305)->insert into c2 select if(gender = 0,'',null) from c1;Query OK, 33554432 rows affected (2 min 18.80 sec)Records: 33554432 Duplicates: 0 Warnings: 0
两张表的磁盘占用差不多。root@ytt-pc:/var/lib/mysql/3305/ytt# ls -sihl总用量 1.9G4085684 933M -rw-r----- 1 mysql mysql 932M 12月 11 10:16 c1.ibd4082686 917M -rw-r----- 1 mysql mysql 916M 12月 11 10:22 c2.ibd
检索方式稍微有些不同,不过效率也差不多。所以说,字符类型不愧为万能类型。
七、枚举类型
1. 最大占用 2 Byte。2. 最大支持 65535 个不同元素。3. MySQL 后台存储以下标的方式,也就是 tinyint 或者 smallint 的方式,下标从 1 开始。4. 排序时按照下标排序,而不是按照里面元素的数据类型。所以这点要格外注意。
创建表 t7。mysql-(ytt/3305)->create table t7(c1 enum('mysql','oracle','dble','postgresql','mongodb','redis','db2','sql server'));Query OK, 0 rows affected (0.03 sec)
1. 最大占用 8 Byte,int64。2. 内部以二进制位的方式存储,对应的下标如果以十进制来看,就分别为 1,2,4,8,...,pow(2,63)。3. 最大支持 64 个不同的元素,重复元素的插入,取出来直接去重。4. 元素之间可以组合插入,比如下标为 1 和 2 的可以一起插入,直接插入 3 即可。
mysql-(ytt/3305)->create table c7(c1 set('mysql','oracle','dble','postgresql','mongodb','redis','db2','sql server'));Query OK, 0 rows affected (0.02 sec)
mysql-(ytt/3305)->INSERT INTO c7WITH RECURSIVE ytt_number (cnt) AS ( SELECT 1 AS cnt UNION ALL SELECT cnt + 1 FROM ytt_number WHERE cnt < pow(2, 7) )SELECT *FROM ytt_number;Query OK, 128 rows affected (0.01 sec)Records: 128 Duplicates: 0 Warnings: 0
示例 10
mysql-(ytt/3305)->select ytt_sample_data_type(1111,222) 'result';+--------------------------+| result |+--------------------------+| The result is: '246642'. |+--------------------------+1 row in set (0.00 sec)
综上所述,日期这块类型的选择遵循以下原则:
4. 如果有保存毫秒类似的需求,最好是用时间类型自己的特性,不要直接用字符类型来代替。MySQL 内部的类型转换对资源额外的消耗也是需要考虑的。
示例 5
binary 和 varbinary 对应了 char 和 varchar 的二进制存储,相关的特性都一样。不同的有以下几点:
示例 6
来看这个 binary 存取的简单示例,还是之前的变量 @a。
切记!这里要提前计算好 @a 占用的字节数,以防存储溢出。
bit 为 MySQL 里存储比特位的类型,最大支持 64 比特位, 直接以二进制方式存储,一般用来存储状态类的信息。比如,性别,真假等。具有以下特性:
示例 7
其实这样的场景,也可以定义为 char(0),这也是类似于 bit 非常优化的一种用法。
那现在我给表 c1 简单的造点测试数据。
把 c1 的数据全部插入 c2。
枚举类型,也即 enum。适合提前规划好了所有已经知道的值,且未来最好不要加新值的情形。枚举类型有以下特性:
示例 8
八、集合类型
集合类型 SET 和枚举类似,也是得提前知道有多少个元素。SET 有以下特点:
示例 9
定义表 c7 字段 c1 为 set 类型,包含了 8 个值,也就是下表最大为 pow(2,7)。
插入 1 到 128 的所有组合。
九、数据类型在存储函数中的用法
函数里除了显式声明的变量外,默认 session 变量的数据类型很弱,随着给定值的不同随意转换。
定义一个函数,返回两个给定参数的乘积。定义里有两个变量,一个是 v_tmp 显式定义为 int64,另外一个 @vresult 随着给定值的类型随意变换类型。
简单调用下。
总结
本篇把 MySQL 基本的数据类型做了简单的介绍,并且用了一些容易理解的示例来梳理这些类型。我们在实际场景中,建议选择适合最合适的类型,不建议所有数据类型简单的最大化原则。比如能用 varchar(100),不用 varchar(1000)。