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

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

i32u32 的转换

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

#[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

利用上述的方法,我们可以实现 MySQL 的 INT UNSIGNED

CREATE TABLE test_int_to_u32(
	hit INT NOT NULL
);

CREATE TABLE test_serial_to_u32(
	id SERIAL PRIMARY KEY
);

依赖

代码演示

要查看完整内容,请先登录