微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PostgreSQL-3-DDL数据定义语言

1、创建/删除新的数据库

\l  查看现有数据库

\h CREATE DATABASE  查看CREATE DATABASE语句说明

\h DROP DATABASE 查看DROP DATABASE语句说明

 

CREATE DATABASE c03_sqlstudy;

\c c03_sqlstudy

创建一个数据库,第三章sql语言学习,并切换为该数据库

 

 

2、修改数据库

\h ALTER DATABASE 查看语句说明

 

ALTER DATABASE c03_sqlstudy RENAME TO c03_sqlstudy_gai; 修改数据库名字,注意不能修改现有数据库名字

ALTER DATABASE c03_sqlstudy OWNER TO u1; 修改数据库所有者

 

 

3、创建/删除新表

\d  查看现有数据库中的匹配关系(包括表格,视图,索引,序列等)

\d tablename  查看tablename表的属性

\h CREATE TABLE  查看CREATE TABLE语句说明

\h DROP TABLE  查看DROP TABLE语句说明

 

CREATE TABLE company(

       No int PRIMARY KEY, 

       name text,

       age int,

       address text

       );

创建一个表格,表名为company,包括4个字段,PRIMARY KEY代表数据库表主键约束

INSERT INTO company VALUES(1,‘jack‘,25,‘aa‘);

INSERT INTO company VALUES(2,‘may‘,40,‘bb‘);

INSERT INTO company VALUES(3,‘ana‘,29,‘cc‘);

插入3条数据

SELECT * FROM company;

查看company表格数据

 

4、约束条件

CREATE TABLE company2(

       No int PRIMARY KEY, 

       name text NOT NULL UNIQUE,

       age int NOT NULL UNIQUE

       );

PRIMARY KEY约束 → 主键约束,1个表中只有1个主键,且不能有NULL值

UNIQUE约束 → 唯一约束防止两个记录在1个特定的列具有相同的值,1个表中可以多个UNIQUE约束

NOT NULL约束 → 该列不能有NULL值

 

CREATE TABLE company3(

       No int PRIMARY KEY,

       salary numeric CHECK(salary>0)

       );

INSERT INTO company3 VALUES(1,10000);

INSERT INTO company3 VALUES(2,‘pual‘,15000);

INSERT INTO company3 VALUES(3,‘allen‘,15000);

INSERT INTO company3 VALUES(4,‘teddy‘,20000);

INSERT INTO company3 VALUES(5,‘mark‘,20000);

INSERT INTO company3 VALUES(6,‘kim‘,10000);

INSERT INTO company3 VALUES(7,‘mary‘,-10000);

CHECK约束 → 添加约束条件,如果条件值为false则不写入表格,例如以上案例中第二条数据无法插入

 

 

5、变更数据库

\h ALTER TABLE 查看ALTER TABLE语句说明

 

添加新列

ALTER TABLE table_name ADD column_name datatype;

ALTER TABLE company ADD gender text;

 

删除

ALTER TABLE table_name DROP COLUMN column_name;

ALTER TABLE company DROP COLUMN gender;

 

修改列的数据类型

ALTER TABLE table_name ALTER COLUMN column_name TYPE datatype;、

ALTER TABLE company ALTER COLUMN No TYPE numeric;

 

设置列为非空

ALTER TABLE table_name ALTER COLUMN column_name SET NOT NULL;

ALTER TABLE company ALTER COLUMN age SET NOT NULL;

 

删除非空设置

ALTER TABLE table_name ALTER COLUMN column_name DROP NOT NULL;

ALTER TABLE company ALTER COLUMN age DROP NOT NULL;

 

添加主键primary key,这里可以是多个列,主键名称这里为‘pkey‘

ALTER TABLE table_name ADD CONSTRAINT MyPrimaryKey PRIMARY KEY (column1,column2...);

ALTER TABLE company ADD CONSTRAINT pkey PRIMARY KEY (No,name);

 

添加UNIQUE约束,这里添加约束名为‘ukey‘

ALTER TABLE table_name ADD CONSTRAINT MyUniqueConstraint UNIQUE (column1,column2...);

ALTER TABLE company ADD CONSTRAINT ukey UNIQUE (name);

 

添加CHECK约束,这里约束名为‘agecheck‘,约束条件为 age>0

ALTER TABLE table_name ADD CONSTRAINT MyUniqueConstraint CHECK (CONDITION);

ALTER TABLE company ADD CONSTRAINT agecheck CHECK (age > 0);

 

删除约束条件

ALTER TABLE table_name DROP CONSTRAINT some_name;

ALTER TABLE company DROP CONSTRAINT pkey;  删除主键 pkey

ALTER TABLE company DROP CONSTRAINT ukey;  删除UNIQUE约束 ukey

ALTER TABLE company DROP CONSTRAINT agecheck;   删除CHECK约束 agecheck

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐