使用 Rust 的 u32 让 PostgreSQL 实现 MySQL 的 INT UNSIGNED

51211
2022/10/13 03:02:57

在上一章我们讨论到 PostgreSQL 没有 UNSIGNED 的问题,本章我们试图通过 rust 的 u32 来映射 PostgreSQL 的 int。

i32u32 的转换

在 Rust 和 PostgreSQL 中,Rust 的 i32 对应 PostgreSQL 的 INTEGER(INT),它们都是有符号的 32 位整数。而 Rust 的 u32 是无符号的 32 位整数。

无论 Rust 的 i32 还是 PostgreSQL 的 INT,当它们的值达到取值范围的最大值时,它们会溢出为最小值。

请看代码:

使用 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
);

依赖

[dependencies]
tokio={version="1", features=["full"]}
sqlx = { version = "0.6", features = [ "runtime-tokio-native-tls" , "postgres" ] }

代码演示