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
PostgreSQL-3-DDL数据定义语言的更多相关文章
- oracle学习笔记(三) DCL 数据控制语言与 DDL 数据定义语言
DCL 数据控制语言 Data control language 之前说过的授权和收权利语句 grant, revoke DDL 数据定义语言 Data define language create ...
- sql 两大类 DDL数据定义语言 和DCL数据控制语言
SQL分为五大类: DDL:数据定义语言 DCL:数据控制语言 DML:数据的操纵语言 DTL:数据事务语言 DQL:数据查询语言. DDL (date definition lang ...
- Hive 官方手册翻译 -- Hive DDL(数据定义语言)
Hive DDL(数据定义语言) Confluence Administrator创建, Janaki Lahorani修改于 2018年9月19日 原文链接 https://cwiki.apache ...
- mysql DDL数据定义语言
DDL数据定义语言 本节涉及MySQL关键字:create.alter(rename,add,chang,modify,drop).drop.delete.truncate等. -- 创建表:-- 数 ...
- DDL数据定义语言
DDL数据定义语言 (一)概述 DDL(Data Definition Language):数据定义语言,用来定义数据库对象,库.表.列等:创建.删除.修改 库,表结构.主要分为操作数据库的DDL和操 ...
- Oracle language types(语言种类) 表的相关操作 DDL数据定义语言
数据定义语言 Data Definition Language Statements(DDL)数据操纵语言 Data Manipulation Language(DML) Statements事务控制 ...
- 【MySQL】DDL数据定义语言的基本用法create、drop和alter(增删改)
DDL 的基础语法 文章目录 DDL 的基础语法 对数据库进行定义 对数据表进行定义 创建表结构(数据表) 设计工具 修改表结构 小结 参考资料 简单复习一波 SQL必知必会 DDL 的英文全称是 D ...
- DDL 数据定义语言
目录 创建数据库(CREATE) 删除数据库(DROP) 修改数据库(ALTER) 创建数据表(CREATE) 数据表的数据属性 数据类型属性(Type) 其他属性(Null,Key,Default, ...
- MySQL之DDL数据定义语言:库、表的管理
库的管理 常用命令 #创建库 create database if not exists 库名 [ character set 字符集名]; create database if not exists ...
- ODPS SQL <for 数据定义语言 DDL>
数据定义语言:(DDL) 建表语句: CREATE TABLE [IF NOT EXISTS] table_name [(col_name data_type [COMMENT col_comment ...
随机推荐
- 代码空间项目 -- InstantiationException的异常
java.lang.InstantiationException实例化异常.当试图通过newInstance()方法创建某个类的实例,而该类是一个抽象类或接口时,抛出该异常. 这次项目中查询type时 ...
- Objectvice-C中的super
/** 狗:哈士奇 */ //僵尸 #import <Foundation/Foundation.h> @interface Dog : NSObject - (void) walk; + ...
- MYSQL进阶学习笔记十八:MySQL备份和还原!(视频序号:进阶_37)
知识点十九:MySQL的备份的还原(38) 一.mysql的备份 1.通过使用mysqldump的命令备份 使用mysqldump命令备份,mysqldump命令将数据库中的数据备份成一个文本文件.表 ...
- Linux 命令行 Tricks
区分文件和目录: ls -F ls -F -R:递归显示目录 仅改变文件的修改时间,而不修改文件的内容: touch filename: 使用 file 命令查看文件类型: ASCII text di ...
- NVIDIA GPU 计算能力
Tesla V100# ARCH= -gencode arch=compute_70,code=[sm_70,compute_70] GTX 1080, GTX 1070, GTX 1060, GTX ...
- C++对C的增强
一.namespace命名空间 1.C++命名空间基本常识所谓namespace,是指标识符的各种可见范围.c++标准程序库中的所有标识符都被定义与一个名为std的namespace中. 1.1:&l ...
- Oracle数据库当前连接数、最大连接数的查询与设置
在开发过程中Oracle数据库有时候连得上,有时候又连不上,提示如下异常“ORA-12519: TNS:no appropriate service handler found 解决”,可能是数据库上 ...
- DataWindow.NET 控件 实现点击列头排序
1.定义字段 Boolean ib_SetSort = true; string is_SortType = " ...
- 查看电脑MAC地址
MAC地址也叫物理地址 1.运行 cmd 输入ipconfig或ipconfig/all
- Spring Boot 学习系列(07)—properties文件读取
此文已由作者易国强授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 传统的properties读取方式 一般的,我们都可以自定义一个xxx.properties文件,然后在工程 ...