欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

[GBase 8s 教程]GBase 8s 创建表格

程序员文章站 2022-07-01 07:53:15
...

GBase 8s 使用 CREATE TABLE 语句来创建数据库表格。

语法
CREATE TABLE 语法格式如下:

CREATE TABLE [ IF NOT EXISTS ] table_name (
   column1 datatype [ check option ] [ default [value|(function value)] ,
   column2 datatype [ check option ] [ default [value|(function value)] ,
   column3 datatype [ check option ] [ default [value|(function value)] ,
   .....
   columnN datatype [,
   PRIMARY KEY(column1[,...])]
) [ extent size M next size N ] [ lock mode [row|page] ];

CREATE TABLE 是一个关键词,用于告诉数据库系统将创建一个数据表。
表名字必需在同一个库中的其它表、 序列、索引、视图或外部表名字中唯一。
CREATE TABLE 在当前数据库创建一个新的空白表,该表将由发出此命令的用户所拥有。
表格中的每个字段都会定义数据类型,如下:
实例
以下创建了一个表,表名为 COMPANY 表格,主键为 ID,NOT NULL 表示字段不允许包含 NULL 值:

CREATE TABLE COMPANY(
   ID             SERIAL         PRIMARY KEY,
   NAME           VARCHAR(40)    NOT NULL,
   AGE            INT            NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         DECIMAL(10,2)
);

接下来我们再创建一个表格,在后面章节会用到:

CREATE TABLE DEPARTMENT(
   ID             SERIAL   PRIMARY KEY,
   DEPT           CHAR(50) NOT NULL,
   EMP_ID         INT      NOT NULL
);

在dbaccess 交互命令中执行

[[email protected] ~]$ dbaccess testdb -

Database selected.

> CREATE TABLE COMPANY(
   ID             SERIAL         PRIMARY KEY,
   NAME           VARCHAR(40)    NOT NULL,
   AGE            INT            NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         DECIMAL(10,2)
);> > > > > >

Table created.

Elapsed time: 0.004 sec

> CREATE TABLE DEPARTMENT(
   ID             SERIAL   PRIMARY KEY,
   DEPT           CHAR(50) NOT NULL,
   EMP_ID         INT      NOT NULL
);> > > >

Table created.

Elapsed time: 0.007 sec

我们可以使用info tables命令来查看表格是否创建成功:

[[email protected] ~]$ dbaccess testdb -

Database selected.

> info tables;


Table name

company            department

Elapsed time: 0.024 sec

info columns for company查看表格信息:

[[email protected] ~]$ dbaccess testdb -

Database selected.

> info columns for company;


Column name          Type                                    Nulls

id                   serial                                  no
name                 varchar(40,0)                           no
age                  integer                                 no
address              char(50)                                yes
salary               decimal(10,2)                           yes
Elapsed time: 0.015 sec

也可以使用dbschema -d DBNAME -t TABNAME -ss 显示完整的SQL语句

[[email protected] ~]$ dbschema -d testdb -t company -ss

DBSCHEMA Schema Utility       GBASE-SQL Version 12.10.FC4G1AEE

{ TABLE "gbasedbt".company row size = 105 number of columns = 5 index size = 9 }

create table "gbasedbt".company
  (
    id serial not null ,
    name varchar(40) not null ,
    age integer not null ,
    address char(50),
    salary decimal(10,2),
    primary key (id)
  ) extent size 16 next size 16 lock mode row;

revoke all on "gbasedbt".company from "public" as "gbasedbt";