在(postgresql)数据库中存储 EUI-64 地址的数据类型

Posted

技术标签:

【中文标题】在(postgresql)数据库中存储 EUI-64 地址的数据类型【英文标题】:What data type for storing EUI-64 address in (postgresql) database 【发布时间】:2013-10-13 21:50:30 【问题描述】:

什么是存储 EUI-64 地址的好数据类型(对于 ZigBee 节点)?

EUI-64 地址基本上是 8 个八位字节。据我所知,它们不应该被视为一个整数,尽管很明显你可以用它们制作一个 64 位整数。使用 bigint 似乎很明显,尽管不幸的是它们被“签名”了,这让它有点混乱。

我可以使用 numeric(8),但是没有内置的转换来表示为十六进制(虽然我可以写一个)。

我可以使用 char(16),但这似乎很浪费。

所有这些选项都可以使用,但每个选项看起来都有些混乱。我只是想知道是否有人对此有任何想法或我没有想到的方式。我目前正在使用 bigint,到目前为止它运行良好。它允许我使用“to_hex”来表示地址,但除非我正确处理符号,否则我可以预见问题。

谢谢。

【问题讨论】:

只有在进行算术运算或小于/大于比较时,被“签名”的值才会导致问题。 【参考方案1】:

我会为它编写自己的数据类型,使用macaddr 的代码作为模板。

【讨论】:

您能详细说明一下并提供一些示例代码吗?没有这个,你的答案不是很有帮助

以上是关于在(postgresql)数据库中存储 EUI-64 地址的数据类型的主要内容,如果未能解决你的问题,请参考以下文章

Sql优化 PostgreSQL存储过程

为啥在 PostgreSQL 存储过程中查询没有“结果数据的目标”?

我应该使用哪种数据类型将图像存储在数据库(PostgreSQL)中?

使用 Java 在 PostgreSQL 中存储时间的最推荐方法是啥?

在 PostgreSQL 中重用存储过程的结果

使用 NestJS 在 PostgreSQL 数据库中存储文件