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;
练习一
# 超级用户创建数据库与用户
# 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 自增长
练习二
# 创建表
# 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;
练习三
# 创建表
# 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);