域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。现在,我们已启用新域名 AXUM.EU.ORG
  • 方案AXUM.RS 域名 = 3000
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名,或者该域名到期,本站将使用免费域名 AXUM.EU.ORG 继续提供服务。

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

i32u32 的转换

无论 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

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

SQL 语句

CREATE TABLE test_int_to_u32(
	hit INT NOT NULL
);

CREATE TABLE test_serial_to_u32(
	id SERIAL PRIMARY KEY
);

依赖

代码演示

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