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

PostgreSQL-3-DDL数据定义语言的更多相关文章

  1. oracle学习笔记(三) DCL 数据控制语言与 DDL 数据定义语言

    DCL 数据控制语言 Data control language 之前说过的授权和收权利语句 grant, revoke DDL 数据定义语言 Data define language create ...

  2. sql 两大类 DDL数据定义语言 和DCL数据控制语言

    SQL分为五大类: DDL:数据定义语言   DCL:数据控制语言     DML:数据的操纵语言  DTL:数据事务语言  DQL:数据查询语言. DDL (date definition lang ...

  3. Hive 官方手册翻译 -- Hive DDL(数据定义语言)

    Hive DDL(数据定义语言) Confluence Administrator创建, Janaki Lahorani修改于 2018年9月19日 原文链接 https://cwiki.apache ...

  4. mysql DDL数据定义语言

    DDL数据定义语言 本节涉及MySQL关键字:create.alter(rename,add,chang,modify,drop).drop.delete.truncate等. -- 创建表:-- 数 ...

  5. DDL数据定义语言

    DDL数据定义语言 (一)概述 DDL(Data Definition Language):数据定义语言,用来定义数据库对象,库.表.列等:创建.删除.修改 库,表结构.主要分为操作数据库的DDL和操 ...

  6. Oracle language types(语言种类) 表的相关操作 DDL数据定义语言

    数据定义语言 Data Definition Language Statements(DDL)数据操纵语言 Data Manipulation Language(DML) Statements事务控制 ...

  7. 【MySQL】DDL数据定义语言的基本用法create、drop和alter(增删改)

    DDL 的基础语法 文章目录 DDL 的基础语法 对数据库进行定义 对数据表进行定义 创建表结构(数据表) 设计工具 修改表结构 小结 参考资料 简单复习一波 SQL必知必会 DDL 的英文全称是 D ...

  8. DDL 数据定义语言

    目录 创建数据库(CREATE) 删除数据库(DROP) 修改数据库(ALTER) 创建数据表(CREATE) 数据表的数据属性 数据类型属性(Type) 其他属性(Null,Key,Default, ...

  9. MySQL之DDL数据定义语言:库、表的管理

    库的管理 常用命令 #创建库 create database if not exists 库名 [ character set 字符集名]; create database if not exists ...

  10. ODPS SQL <for 数据定义语言 DDL>

    数据定义语言:(DDL) 建表语句: CREATE TABLE [IF NOT EXISTS] table_name [(col_name data_type [COMMENT col_comment ...

随机推荐

  1. Xcode工程断点调试失效

    1.我解决的是方法是,选择Product---->Edit Scheme------>(这里进入后会有Info,Arguments,Options,Diagnostics)选择Info-- ...

  2. 一看就会,科目三靠边停车30cm技巧!再也不怕不会停车了!

    靠边停车是科目三考试的最后一关,如果在这一关失败,那之前所有的努力都功亏一篑了,你感觉吃不吃亏?就连我们自己平时开车,轮胎万一与路边石阶刮蹭,就会造成不小的伤害.那么靠边停车时有哪些注意要点呢?请和小 ...

  3. 用mingw-w64 编译 x64 位的ffmpeg

    http://blog.sina.com.cn/s/blog_6125d067010168dt.html 工作中用到了ffmpeg x64. 发现编译出来x64的ffmpeg,很不容易.特记录下来.原 ...

  4. linux应用之php开发环境lamp搭建(centos)

    搭建linux+apache+mysql+php环境   1.安装apache: yum install httpd httpd-devel  启动apache: /etc/init.d/httpd ...

  5. linux系统配置之服务程序的开机自启动(centos)

    CentOS安装好apache.mysql等服务器程序后,并没有设置成开机自动启动的,为避免重启后还要手动开启web等服务器,还是做下设置好,其实设置很简单,用chkconfig命令就行了. 例如,要 ...

  6. Understand JavaScript’s “this” With Clarity, and Master It

    The this keyword in JavaScript confuses new and seasoned JavaScript developers alike. This article a ...

  7. Windows_Program_Via_C_Translate_Win32编程的背景知识/基础知识_包括基本输入输出机制介绍

    Some Basic Background Story of The Win32 APIs Win32 API背景故事/背景知识 The Win32 application programming i ...

  8. C# 获取QQ群数据的实现

    一,分析 1,群数据获取 当访问http://qun.qq.com/air/#mygroup我们通过Fiddler可以查看到QQ群列表是从http://qun.qq.com/air/group/min ...

  9. php字符编码转换中的iconv与mb_convert_encoding用法

    iconv ( 'UTF-8' , 'GBK' , $str ); //将$str字符串 utf-8 编码转换成 gbk: 另外,5.4.0 这个版本起,字符非法时候会返回 FALSE,除非在输出字符 ...

  10. UnicodeEncodeError: 'ascii' codec can't encode character u'\u5929' in position 2: ordinal not in range(128)

    UnicodeEncodeError: 'ascii' codec can't encode character u'\u5929' in position 2: ordinal not in ran ...