• Home
  • 如何在金仓数据库KingbaseES中新建一个数据库?新建一个表?给表添加一个字段?
  • 巴西世界杯四强

如何在KingbaseES(金仓数据库)中新建一个数据库?新建一个表?给表添加一个字段?

摘要

KingbaseES(金仓数据库)新建数据库、创建表、添加字段全流程实战指南,涵盖 KES 数据库属性、sys_database 系统表查询、sys_database_size 磁盘空间监控;基于图形界面快速创建数据库、表及字段;SQL 语句详解:CREATE DATABASE、createdb、CREATE TABLE、ALTER TABLE ADD COLUMN;模板库(template0/template1)、编码(UTF8/GBK/GB18030)、表空间管理、权限配置、DDL 脚本生成;适用于 ksql/psql 客户端、命令行工具和可视化管理工具的数据库对象管理与数据定义语言(DDL)最佳实践。

目录

问题文档概述数据库属性创建一个KES数据库

基于图形界面创建一个KES数据库通过 CREATE DATABASE 创建一个KES数据库通过 createdb 创建一个KES数据库 新建一个表

基于图形界面新建一个表通过 CREATE TABLE 新建一个表 给表添加一个字段

基于图形界面给表添加字段通过 ALTER TABLE 给表添加字段

1. 问题

如何在 KingbaseES(金仓数据库)中:

新建一个数据库?在该数据库中新建一个表?给已有表添加一个字段?

2. 概述

本文将从 KingbaseES 的基本概念与属性入手,详细介绍三种方式创建数据库,并演示如何通过图形界面与 SQL 语句完成表的创建和字段的添加。阅读完本文,您将掌握在 KingbaseES 中进行常见 DDL(数据定义语言)操作的全流程。

3. 数据库属性

在 KingbaseES 中,数据库(Database)是多个数据库对象(表、索引、序列、视图等)的命名集合。一个实例(Instance)中可以包含多个数据库。每个数据库内的对象相互隔离,但可以通过系统表如 sys_database 和 sys_schema 查看和管理。

sys_database:列出实例中所有数据库名称、所有者、编码等信息。sys_database_size(‘dbname’):返回指定数据库所占磁盘空间大小。模板库:template0、template1,用于在创建新库时复制初始结构。

-- 查看已有数据库列表

SELECT datname, datdba, encoding, datcollate, datctype

FROM sys_database;

-- 查看 test 库大小

SELECT sys_database_size('test');

4. 创建一个KES数据库

在 KingbaseES 中,常见的创建数据库方式有三种:

基于图形界面通过 SQL 语句 CREATE DATABASE通过命令行工具 createdb

4.1. 基于图形界面创建一个KES数据库

启动 KingbaseES 管理客户端,连接到目标实例。

在左侧导航树中,右键点击 “数据库” 节点,选择 “新建数据库”。

在弹出的向导中,按页填写信息:

基本属性页:

名称:指定新数据库名,不得与现有库重复。属主:默认当前用户,可更改为其他已存在角色。编码:默认为 UTF8,可选 ASCII、GBK、GB18030。 权限页:为其他用户/角色分配 CONNECT、CREATE 等权限。DDL 页:查看最终生成的 CREATE DATABASE 语句。 点击 确定 完成创建。

在向导中,可随时切换到 DDL 页,复制生成的 SQL,便于后续脚本化部署。

4.2. 通过 CREATE DATABASE 创建一个KES数据库

使用 SQL 语句直接在客户端(如 ksql、psql)中执行:

-- 仅指定库名,默认属主为当前连接用户

CREATE DATABASE mydb;

-- 指定属主和编码

CREATE DATABASE mydb

WITH

OWNER = dbuser

ENCODING = 'UTF8'

TEMPLATE = template1

TABLESPACE = pg_default;

注意事项

数据库名必须符合标识符规则,避免使用保留字。普通用户只能创建属于自己的数据库;若要创建其他属主的库,需使用超级用户 system。

4.3. 通过 createdb 创建一个KES数据库

createdb 是 KingbaseES 提供的命令行辅助工具,本质上会登录实例并执行 CREATE DATABASE。

# 使用默认参数,以当前系统用户名创建同名数据库

$ createdb demo

# 指定端口、主机、属主等

$ createdb -h 127.0.0.1 -p 54321 -U system -O dbuser -T template1 demo

-h:服务器地址-p:端口号-U:连接用户名-O:新库属主-T:指定模板库

5. 新建一个表

创建完数据库后,需要在其中定义表结构。KingbaseES 的表创建方式也有两种:图形界面与 SQL 语句。

5.1. 基于图形界面新建一个表

在管理客户端中,连接到目标数据库 mydb。展开左侧树形结构至 “模式(Schemas)” → “public” → “表(Tables)”。右键 “表”,选择 “新建表”。在向导中填写:

表名、表空间列定义:逐行添加列名、数据类型、长度、是否可空、默认值等。主键/索引:在相关页签定义主键或其他索引。 查看生成的 CREATE TABLE DDL,点击确认完成。

5.2. 通过 CREATE TABLE 新建一个表

在 SQL 客户端中执行:

-- 示例:创建用户表

CREATE TABLE public.users (

id BIGSERIAL PRIMARY KEY,

username VARCHAR(50) NOT NULL UNIQUE,

email VARCHAR(100),

created_at TIMESTAMP WITHOUT TIME ZONE DEFAULT CURRENT_TIMESTAMP

);

-- 查看表结构

\d+ public.users;

BIGSERIAL:自增主键VARCHAR(n):变长字符NOT NULL:非空约束UNIQUE:唯一约束DEFAULT:默认值

6. 给表添加一个字段

当业务需求变化时,可能需要在已有表中增加新字段。KingbaseES 支持在图形界面或通过 ALTER TABLE 完成。

6.1. 基于图形界面给表添加字段

在管理客户端中,连接到 mydb,找到目标表 public.users。右键点击该表,选择 “修改表”。在 “列” 页签点击 “添加”,输入新列名、类型、默认值、约束等。确认后,客户端会执行相应的 ALTER TABLE 语句。

6.2. 通过 ALTER TABLE 给表添加字段

在 SQL 客户端中执行:

-- 为 users 表新增 last_login 字段

ALTER TABLE public.users

ADD COLUMN last_login TIMESTAMP WITHOUT TIME ZONE;

-- 带默认值且非空

ALTER TABLE public.users

ADD COLUMN status VARCHAR(20) NOT NULL DEFAULT 'active';

ADD COLUMN:添加新列可同时指定 NOT NULL、DEFAULT、CHECK 等约束

查看修改结果:

-- 再次查看表结构

\d+ public.users;

通过以上步骤,您已掌握 KingbaseES 中创建数据库、建表与扩展表结构的核心操作。建议在生产环境中,将这些 DDL 操作纳入版本控制,并在测试库演练后,再应用到线上数据库,以确保安全无误。祝您使用愉快!

7. 结论

通过本文的介绍,您已经全面掌握了在 KingbaseES(金仓数据库)中创建数据库、建表以及给表添加字段的三种主流方法:图形界面操作、SQL DDL 语句(CREATE DATABASE/CREATE TABLE/ALTER TABLE)和命令行工具(createdb)。在实际应用中,建议您:

结合版本控制:将所有 DDL 脚本纳入 Git 等版本管理系统,便于回滚与审计。规范命名与编码:统一数据库、表、字段命名规则,确保字符集(UTF8、GBK、GB18030)与排序规则一致。权限与安全:合理分配属主与访问权限,使用最小权限原则保障数据安全。测试与演练:在测试环境中演练所有操作后,再推送至生产环境,降低因脚本错误带来的风险。

掌握这些核心操作与最佳实践,将助您在 KingbaseES 中高效、可靠地管理数据库架构,提升开发与运维的自动化与可维护性。如需进一步深入,请查阅官方文档或探索更多高级特性,例如表分区、并行查询与逻辑复制。祝您数据库管理之旅顺利!

Copyright © 2088 1986世界杯_意大利世界杯 - zlrxcw.com All Rights Reserved.
友情链接