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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |