Skip to content

本地数据库管理 (db 命名空间)

管理多个独立 SQLite 数据库实例,支持对每个数据库执行原始 SQL 和参数化查询。

所有方法均位于 db 命名空间下。

方法列表

方法名描述权限要求
create创建新的本地数据库Db::Create
read获取数据库元信息Db::Read
update重命名数据库Db::Update
delete删除数据库并清理文件Db::Delete
list列出所有数据库Db::List
exec_sql执行原始 SQL(允许参数和复合语句)Db::ExecSql
exec_templating参数化 SQL 执行,参数必须为数组Db::ExecSql

数据库存储

所有本地数据库文件默认存放在配置文件 db_path 指定的目录下,格式为 {db_path}/{name}.db(SQLite)。

配置文件默认路径为 ./db/

连接池管理

服务端维护一个 DbRegistryManager 连接池,对每个注册的数据库实例缓存 DatabaseConnection

当某个数据库超过 max_lifetime_ms 毫秒未被访问时,连接池会自动关闭并回收该连接。

权限

本地数据库使用独立的 Db 权限体系,与 NodeGet 主权限体系并列。Token 需要拥有对应的 Db::Xxx 权限才能执行相应操作。

rust
pub enum Db {
    List,
    Read,
    Create,
    Update,
    Delete,
    ExecSql,
}

授权 Scope 为 Scope::Global(即权限对所有数据库实例生效)。


Create

创建一个新的本地数据库实例。会在 db_path 目录下创建 {name}.db SQLite 文件,同时在主数据库的 db_registry 表中注册一条记录。

请求:

json
{
  "jsonrpc": "2.0",
  "method": "db_create",
  "params": [
    "TOKEN",
    "my_database"
  ],
  "id": 1
}

响应 (成功):

json
{
  "jsonrpc": "2.0",
  "result": {
    "success": true,
    "data": {
      "name": "my_database",
      "file_path": "./db/my_database.db"
    }
  },
  "id": 1
}

错误码:

代码说明
102Permission Denied
108Invalid input (name 含非法字符)
103Database error (已存在)

Read

获取数据库实例的元信息(注册状态、文件路径、是否活跃在连接池中等)。

请求:

json
{
  "jsonrpc": "2.0",
  "method": "db_read",
  "params": [
    "TOKEN",
    "my_database"
  ],
  "id": 1
}

响应 (成功):

json
{
  "jsonrpc": "2.0",
  "result": {
    "success": true,
    "data": {
      "id": 1,
      "name": "my_database",
      "created_at": 1748102400000,
      "active": true
    }
  },
  "id": 1
}

错误码:

代码说明
102Permission Denied
105Database not found

Update

重命名数据库实例。会同时重命名磁盘上的 .db 文件和连接池中的条目。

请求:

json
{
  "jsonrpc": "2.0",
  "method": "db_update",
  "params": [
    "TOKEN",
    "old_name",
    "new_name"
  ],
  "id": 1
}

响应 (成功):

json
{
  "jsonrpc": "2.0",
  "result": {
    "success": true,
    "data": {
      "id": 1,
      "name": "new_name",
      "created_at": 1748102400000
    }
  },
  "id": 1
}

错误码:

代码说明
102Permission Denied
105Database not found
108new_name 已存在
112I/O error (重命名文件失败)

Delete

删除数据库实例。从连接池中移除、从 db_registry 表中删除记录、并删除磁盘上的 .db / .db-wal / .db-shm 文件。

请求:

json
{
  "jsonrpc": "2.0",
  "method": "db_delete",
  "params": [
    "TOKEN",
    "my_database"
  ],
  "id": 1
}

响应 (成功):

json
{
  "jsonrpc": "2.0",
  "result": {
    "success": true
  },
  "id": 1
}

错误码:

代码说明
102Permission Denied
105Database not found

List

列出所有已注册的数据库实例。

请求:

json
{
  "jsonrpc": "2.0",
  "method": "db_list",
  "params": [
    "TOKEN"
  ],
  "id": 1
}

响应 (成功):

json
{
  "jsonrpc": "2.0",
  "result": {
    "success": true,
    "data": [
      {
        "id": 1,
        "name": "my_database",
        "file_path": "./db/my_database.db",
        "db_connections": 1,
        "max_lifetime_ms": null,
        "created_at": 1748102400000,
        "is_active": true
      },
      {
        "id": 2,
        "name": "another_db",
        "file_path": "./db/another_db.db",
        "db_connections": 0,
        "max_lifetime_ms": 3600000,
        "created_at": 1748102500000,
        "is_active": false
      }
    ]
  },
  "id": 1
}

字段说明:

字段类型说明
idi64db_registry 表中的主键 ID
nameString数据库名称
file_pathStringSQLite 文件在磁盘上的绝对路径
db_connectionsOption<i32>当前活跃连接数
max_lifetime_msOption<i64>连接空闲超时时间(毫秒),null=永不超时
created_ati64创建时间戳(毫秒)
is_activebool是否正在连接池中(可立即使用)

Exec Sql

对指定本地数据库执行原始 SQL 语句。支持参数化查询(SQL 中使用 $1, $2 占位符,SQLite 和 PostgreSQL 都支持该格式)。

SELECT / PRAGMA / EXPLAIN / WITH 语句自动返回结果行,其余语句(INSERT / UPDATE / DELETE / DDL / PRAGMA 写操作等)返回影响行数。

注意事项

  • SQL 类型判断使用 trim_start_matches + to_uppercase 后检查前缀
  • 多语句(含 ;不被禁止,由数据库引擎自行处理
  • 参数化查询防止 SQL 注入
  • 使用 $1, $2... 格式的命名参数(SQLite 和 PostgreSQL 均支持)

请求:

json
{
  "jsonrpc": "2.0",
  "method": "db_exec_sql",
  "params": [
    "TOKEN",
    "my_database",
    "SELECT * FROM users WHERE age > $1",
    [
      18
    ]
  ],
  "id": 1
}

响应 (成功):

json
{
  "jsonrpc": "2.0",
  "result": {
    "success": true,
    "data": [
      {
        "id": 1,
        "name": "Alice",
        "age": 25,
        "email": "[email protected]"
      },
      {
        "id": 2,
        "name": "Bob",
        "age": 30,
        "email": "[email protected]"
      }
    ],
    "row_count": 2
  },
  "id": 1
}

对于 DML 操作 (INSERT/UPDATE/DELETE/DDL),data 为空数组,row_count 为受影响的行数:

json
{
  "jsonrpc": "2.0",
  "result": {
    "success": true,
    "data": [],
    "row_count": 3
  },
  "id": 1
}

参数说明:

位置类型说明
0StringToken 字符串
1String目标数据库名称
2StringSQL 语句(支持 $1, $2 占位符)
3array / null参数数组,对应 $1, $2...。可传 null

JSON 参数类型映射到 SeaORM Value:

JSON 类型SeaORM Value说明
nullValue::Json(None)
boolValue::Bool
number (i64)Value::BigInt
number (u64)Value::BigUnsigned
number (f64)Value::Double
stringValue::String
array/objectValue::Json序列化为 JSONB 存储

错误码:

代码说明
102Permission Denied
103Database error (数据库未注册 / SQL 执行失败)
108Invalid input (参数格式错误)

Exec Templating

参数化 SQL 执行。与 exec_sql 功能相同,但要求 params 必须为数组(不能为 null)。

这是推荐的接口,用于确保所有用户输入都通过参数化查询传入,防止 SQL 注入。

请求:

json
{
  "jsonrpc": "2.0",
  "method": "db_exec_templating",
  "params": [
    "TOKEN",
    "my_database",
    "SELECT * FROM users WHERE name = $1",
    [
      "Alice"
    ]
  ],
  "id": 1
}

响应格式exec_sql 完全一致。

错误码:

代码说明
108params 格式错误(必须为数组或null)
其他与 exec_sql 相同