ip地址用什么数据类型存储
1. 分析如何使用int类型存储一个ipv4地址
使用int类型存储一个ipv4地址为IP地址(IPV4)转换为int类型。
ip地址是一个32位的二进制数,实际上是4个字节,点分十进制表示为(a.b.c.d)a、b、c、d的值都是(0-255),例如ip地址(192.168.0.1)就是一个合格ip地址,可以知道a、b、c、d这些字段都是一个无符号字节表示的。
2. ip数据报在电脑是怎么存储的
如果是IPv4类型,那么将IP转为INT UNSIGNED存储在数据库能节约内存,INET_ATON()和INET_NTOA()可以管理ip地址在字符串和数字值之间的转换。
3. sqlServer建表存储Ip地址应该使用哪种数据类型
varchar即可。
sqlserver中varchar最大长度是8000,但是可以使用varchar(max),可以达到2G。
关于解释:
有var前缀的,表示是实际存储空间是变长的,varchar,nvarchar
所谓定长就是长度固定的,当输入的数据长度没有达到指定的长度时将自动以英文空格在其后面填充,使长度达到相应的长度;而变长字符数据则不会以空格填充,比较例外的是,text存储的也是可变长。
4. IP地址属于什么数据类型
int,varcahr是数据库中的,而数据库没有特定的IP类型的。
而int范围不能满足ip的要求,所以只能是
varchar
5. IP地址存储在mysql中用什么字段
用char()类型,因为IP地址基本定长,如114.114.114.114,为15个字符,最少也是如8.8.8.8,为7个字符,但非常少用这样的IP,一般过都是12-15个字符长度,用varchar()变长类型的话会因此减慢数据库速度
6. C语言中,IPv4和IPv6地址用什么数据格式存储
ipv4中的ip地址长度才为32位 ,实际上还会包含报头、版本号、记录上层信息的数据结构等等。不是一个数据类型就可以表示的,都是采用结构体的形式。
有兴趣可以看看Tcp_ip协议(共3卷)。
7. IP地址格式是什么样的
例如,盐城市信息网络中心的服务器的IP地址为210.73.140.2,对于该IP地址,我们可以把它分成网络标识和主机标识两部分,这样上述的IP地址就可以写成:
网络标识:210.73.140.0
主机标识: 2
合起来写:210.73.140.2
8. 什么是存储在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)柱。这取决于有多少数据要存储,这可能是非常浪费的(为什么我们需要存储的点?)