使用 Rust 的 u32 让 PostgreSQL 实现 MySQL 的 INT UNSIGNED
51200
2022/10/13 03:02:57
在上一章我们讨论到 PostgreSQL 没有 UNSIGNED 的问题,本章我们试图通过 rust 的 u32 来映射 PostgreSQL 的 int。
i32
和 u32
的转换
在 Rust 和 PostgreSQL 中,Rust 的 i32
对应 PostgreSQL 的 INTEGER(INT)
,它们都是有符号的 32 位整数。而 Rust 的 u32
是无符号的 32 位整数。
无论 Rust 的 i32
还是 PostgreSQL 的 INT
,当它们的值达到取值范围的最大值时,它们会溢出为最小值。
请看代码:
#[test]
fn test_max_i32_plus_1() {
let max_i32 = i32::max_value();
let min_i32 = i32::min_value();
let from_max_i32 = (max_i32 as u32) + 1;
let from_min_i32 = min_i32 as u32;
assert!(from_max_i32 == from_min_i32);
}
使用 Rust 的 u32
让 PostgreSQL 实现 MySQL 的 INT UNSIGNED
SQL 语句
CREATE TABLE test_int_to_u32(
hit INT NOT NULL
);
CREATE TABLE test_serial_to_u32(
id SERIAL PRIMARY KEY
);