zoukankan      html  css  js  c++  java
  • 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, 

           name text NOT NULL UNIQUE,

           salary numeric CHECK(salary>0)

           );

    INSERT INTO company3 VALUES(1,'jack',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

  • 相关阅读:
    DCR挖矿成本¥355.92,市价¥346.24——五大币种挖矿成本分析 2018-08-7
    智者见智——区块链3.0与未来
    梭哈10万入场,拿住不放,3年后收益过十亿,币圈传奇—大空翼
    从路人甲到叱咤币圈的神话:“打死也不卖币”的宝二爷
    小白眼里的区块链和币圈 —— 持币待涨的故事
    区块链如何赋能网络互助行业?来自众托帮+区块链的应用、车车助+纷享车链AutoChain应用
    中国青年网记者-阿里巴巴王坚:互联网已成为世界发展的基础设施
    读者咩叭:畅谈经济未来
    中青网财经:请一位心理学博士当CTO 只有马云敢这么做
    云科技时代:阿里云创造者写了《在线》,这是一本怎样的书?
  • 原文地址:https://www.cnblogs.com/swefii/p/10587383.html
Copyright © 2011-2022 走看看