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";