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

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 交互命令中执行

[gbasedbt@localhost ~]$ 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命令来查看表格是否创建成功:

[gbasedbt@localhost ~]$ dbaccess testdb -

Database selected.

> info tables;


Table name

company            department

Elapsed time: 0.024 sec

info columns for company查看表格信息:

[gbasedbt@localhost ~]$ 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语句

[gbasedbt@localhost ~]$ 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";

你可能感兴趣的:(GBase,8s,#,GBase,8s,教程,数据库)