PostGreSQL基本操作

CLI连接Postgresql:

1、切换至postgres用户
# su - postgres
# psql 以postgres用户身份连接到postgres数据库
# psql --username=neo123 -W -d hello -h localhost -p 5432 以neo123用户身份连接到hello数据库
2、系统直接使用psql命令
# psql --help 查看命令帮助
# psql --username=neo123 -d hello -W -h localhost -p 5432

Navicat for PostgreSQL连接
数据库操作管理命令

使用帮助:
# ? 全局帮助
# \h \help SQL命令帮助
# \h CREATE USER 具体SQL语句使用帮助
创建用户
# CREATE USER neo123 WITH ENCRYPTED PASSWORD 'neo123';
创建数据库(指定数据库所有者)
# CREATE DATABASE hello WITH OWNER neo123;
修改数据库
# ALTER DATABASE hello RENAME hello1;
删除用户(如果用户是某数据库的owner,那先得删除数据库)
# DROP DATABASE hello;
# DROP USER neo123;
# \q 退出数据库控制台
创建模式(以neo123用户登陆hello数据库)
# CREATE SCHEMA schema1;
# \dn 列出hello数据库所有模式,默认数据库都包含一些public模式
hello=> \dn
架构模式列表
名称 | 拥有者
---------+----------
public | postgres
schema1 | neo123
(2 行记录)
# \help DROP SCHEMA 删除模式
创建表
# hello=> CREATE TABLE tb_emp1 (id INT, name VARCHAR(25),deptID INT,salary FLOAT); 默认不指明模式,是创建在public模式下
# CREATE TABLE schema1.tb_emp1 (id INT, name VARCHAR(25),deptID INT,salary FLOAT); 在特定的模式下创建表

主键约束

主键约束:要求主键列数据唯一,并且不能为空,主键能够唯一地标识表中的一条记录,结合外键来定义不同数据表之间的关系,加快查询速度
主键分类:单字段主键和多字段联合主键
单字段主键定义:
# CREATE TABLE tb_emp1 (id INT PRIMARY KEY, name VARCHAR(25),deptID INT,salary FLOAT);
# CREATE TABLE tb_emp1 (id INT, name VARCHAR(25),deptID INT,salary FLOAT, PRIMARY KEY (id));
多字段联合主键定义:
# CREATE TABLE tb_emp1 (id INT, name VARCHAR(25),deptID INT,salary FLOAT,PRIMARY KEY (id,deptID));
查看表结构:
# \d tb_emp1;
# \d public.tb_emp1;
# \d schema1.tb_emp1;

外键约束:

外键约束是用在两个表的数据之间建立连接,它可以是一列或者多列,一个表可以有一个或者多个外键,外键对应的是参照完整性,一个表的外键可以为空值,若不为空值,则每一个外键必须等于另一个表中主键的某个值。
创建外键约束:
# CREATE TABLE tb_emp2 (id INT PRIMARY KEY,name VARCHAR(25),deptID INT,salary FLOAT,CONSTRAINT fk_emp_dept1 FOREIGN KEY (deptID) REFERENCES tb_emp1(id)); 外键约束名字fk_emp_dept1
# 当主表(主键表)是采用多字段联合主键,从表(外键表)也是需要多字段定义外键,且字段数量一致

非空约束

非空约束(Not null constraint)指字段值不能为空,添加数据时没有指定数据,将会报错。
定义非空约束:
# 字段名 数据类型 NOT NULL

唯一性约束

唯一性约束要求添加该字段的值唯一,允许为空,且只能一个空值,可以实现一列或几列不出现重复值
定义唯一性约束:
# 字段名 数据类型 UNIQUE

默认约束

默认约束(Default Constraint)指定某列的默认值,插入数据时,不指定此列数据,将用默认值代替
定于默认约束:
# 字段名 数据类型 DEFAULT 默认值

修改表属性
# 修改表名字
# ALTER TABLE tb_old RENAME TO tb_new;
# ALTER TABLE tb_emp1 RENAME TO tb_empone;
# 修改表字段数据类型
# ALTER TABLE tb_name ALTER COLUMN 字段名  TYPE  数据类型;
# ALTER TABLE tb_empone ALTER COLUMN name TYPE CHARACTER(40);
# 修改表字段名
# ALTER TABLE tb_name RENAME column_name_old TO column_name_new;
# ALTER TABLE tb_empone RENAME name TO name1;
# 在表中添加字段
# ALTER TABLE tb_name ADD COLUMN column_name data_type;
# ALTER TABLE tb_empone ADD COLUMN age INT;
# ALTER TABLE tb_empone ADD COLUMN mother CHARACTER(25) NOT NULL;
# 在表中删除字段
# ALTER TABLE tb_name DROP column_name;
# ALTER TABLE tb_empone DROP mother;
# 删除表的外键约束
# ALTER TABLE tb_name DROP CONSTRAINT 外键约束名;
# ALTER TABLE tb_emp2 DROP CONSTRAINT fk_emp_dept1;
练习一
1.1.png

1.2.png

# 超级用户创建数据库与用户
# postgres=# CREATE USER admin WITH ENCRYPTED PASSWORD 'admin123';
# CREATE DATABASE company WITH OWNER admin;
# 切换普通用户操作数据库
# ~]# psql -U admin -h localhost -p 5432 -W -d company
# 创建offices表
# company=> CREATE TABLE offices (
# company(> officeCode INT NOT NULL UNIQUE,
# company(> city VARCHAR(50) NOT NULL,
# company(> address VARCHAR(50) NOT NULL,
# company(> country VARCHAR(50) NOT NULL,
# company(> postalCode VARCHAR(50) NOT NULL UNIQUE,
# company(> PRIMART KEY (officeCode));
# 创建employees表
# company=> CREATE TABLE employees (
# employeeNumber SERIAL PRIMARY KEY,
# lastName VARCHAR(50) NOT NULL,
# firstName VARCHAR(50) NOT NULL,
# mobile VARCHAR(25) NOT NULL UNIQUE,
# officeCode INT NOT NULL,
# jobTitle VARCHAR(50) NOT NULL,
# birth DATE,
# note VARCHAR(255),
# sex VARCHAR(5),
# CONSTRAINT "office_fk" FOREIGN KEY(officeCode) REFERENCES offices(officeCode));
# SERIAL 自增长

练习二
2.1.png

# 创建表
# company=> CREATE TABLE customers (
# company(> c_num SERIAL PRIMARY KEY,
# company(> c_name VARCHAR(50),
# company(> c_contact VARCHAR(50),
# company(> c_city VARCHAR(50),
# company(> c_birth DATE NOT NULL);
# 修改c_name字段数据类型为VARCHAR(70)
# ALTER TABLE customers ALTER COLUMN c_name TYPE VARCHAR(70);
# 修改c_contact字段名为c_phone
# ALTER TABLE customers RENAME c_contact TO c_phone;
# 增加c_gender字段,数据类型CHAR(1)
# ALTER TABLE customers ADD c_gender CHAR(1);
# 将表名修改为customers_info
# ALTER TABLE customers RENAME TO customers_info;
# 删除字段c_city
# ALTER TABLE customers_info DROP c_city;

练习三
3.1.png

# 创建表
# company=> CREATE TABLE orders (
# company(> o_num SERIAL PRIMARY KEY,
# company(> o_date DATE,
# company(> c_id VARCHAR(50));
# 修改c_id字段数据类型为INT
# ALTER TABLE orders ALTER COLUMN c_id TYPE INT;
# 以上修改报错: 您可能需要指定"USING c_id::integer"。
# ALTER TABLE orders ALTER COLUMN c_id SET DATA TYPE INT; (正确)
# c_id添加外键约束,关联customers表中主键c_num
# ALTER TABLE orders ADD CONSTRAINT "c_id_num" FOREIGN KEY(c_id) REFERENCES customers_info(c_num);

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,649评论 18 139
  • SQL语言基础 本章,我们将会重点探讨SQL语言基础,学习用SQL进行数据库的基本数据查询操作。另外请注意本章的S...
    厲铆兄阅读 5,320评论 2 46
  • 月上柳梢影婆娑 河畔青芜意朦胧 小楼阑珊遗旧梦 路人何故入夜来
    寒清墨影阅读 271评论 1 3
  • 标签(空格分隔): java StringBuilder——字符串拼接多般是使用StringBuilder类,以及...
    背影杀手不太冷阅读 1,200评论 0 1
  • 作为一名vim迷,使用任何的ide都不能少了这款插件,当使用了brackets后就迫不及待的去装上这款vimder...
    小小机器人阅读 997评论 0 1