postgreSQL入门

PostgreSQL 教程

约束条件

csharp 复制代码
not null, 不能为空
unique, 在所有数据中必须唯一
check, 字段设置条件
default, 字段默认值
primary(not null, unique), 主键, 不能为空且不能重复 

数据库操作

php 复制代码
create database [name]; // 建立数据库
drop database [name]; // 删除数据库
\c [database_name] // 连接其他数据库 
\l // 列出所有数据库
\? // 查看 psql 命令
\q // 退出 psql
// 改名
ALTER DATABASE exp3_1_complicated_query RENAME TO exp3_1;

PostgreSQL 数据类型 | 菜鸟教程 (runoob.com)

表格操作

创建表格

sql 复制代码
CREATE TABLE COMPANY(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);
sql 复制代码
CREATE TABLE DEPARTMENT(
   ID INT PRIMARY KEY      NOT NULL,
   DEPT           CHAR(50) NOT NULL,
   EMP_ID         INT      NOT NULL
);
sql 复制代码
CREATE TABLE COMPANY3(
   ID INT PRIMARY KEY     NOT NULL,
   NAME           TEXT    NOT NULL,
   AGE            INT     NOT NULL UNIQUE,
   ADDRESS        CHAR(50),
   SALARY         REAL    DEFAULT 50000.00
);

插入数据

sql 复制代码
create table test(id int, body varchar(100));
insert into(test(id,body) values(1, 'hello,postgresql');

查询数据

csharp 复制代码
select * from test; // 查询数据

更新数据

chsarp 复制代码
update test set name = 'mayun' where id = 1; // 更新数据
delete from test where id = 1; // 删除数据

表格操作

php 复制代码
\d // 查看当前数据库所有表格
\d [table_name] // 列出某一张表格的结构
DROP TABLE table_name; // 删除表格

数据类型

php 复制代码
timestamp : 日期和时间
date : 日期,无时间
time : 时间
Schema

PostgreSQL 模式(SCHEMA)可以看着是一个表的集合。

一个模式可以包含视图、索引、数据类型、函数和操作符等。

相同的对象名称可以被用于不同的模式中而不会出现冲突,例如 schema1 和 myschema 都可以包含名为 mytable 的表。

使用模式的优势:

  • 允许多个用户使用一个数据库并且不会互相干扰。
  • 将数据库对象组织成逻辑组以便更容易管理。
  • 第三方应用的对象可以放在独立的模式中,这样它们就不会与其他对象的名称发生冲突。

模式类似于操作系统层的目录,但是模式不能嵌套。

scharp 复制代码
#创建schema: 
create schema myschema;

create table myschema.company(
   ID   INT              NOT NULL,
   NAME VARCHAR (20)     NOT NULL,
   AGE  INT              NOT NULL,
   ADDRESS  CHAR (25),
   SALARY   DECIMAL (18, 2),
   PRIMARY KEY (ID)
);

#删除schema: 
drop schema myschema;

#删除一个模式以及其中包含的所有对象:
DROP SCHEMA myschema CASCADE;

# 列出所有模式 (schema )
\dn 
# 显示特定 schema 的所有 table
\d <schema>.*

其余操作

php 复制代码
\t // 只显示元组
\! cls // 清屏 在 Windows 系统中
php 复制代码
-- 删除唯一索引
drop index uk_users_name;
php 复制代码
-- 删除唯一索引
drop index if EXISTS uk_users_name;
php 复制代码
create table undergraduate(
sno char(10) primary key not null,
sname char(10) not null unique,
ssex char(2) not null check(ssex = '男' or ssex = '女'),
birthday date not null, 
polity char(20) default '群众'
); 

create table sc(
sno char(10) not null,
cno char(10) not null,
grade real
);

// check(date > 2019-10-22),

参考资料

零基础入门PostgreSQL · 语雀

相关推荐
不羁。。1 分钟前
【撸靶笔记】第七关:GET - Dump into outfile - String
数据库·笔记·oracle
yangchanghua1112 小时前
pgsql 如何查询今天范围内的数据(当天0点0分0秒 - 当天23点59分59秒....)
数据库·pgsql
larance2 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
python_chai2 小时前
从数据汇总到高级分析,SQL 查询进阶实战(下篇)—— 分组、子查询与窗口函数全攻略
数据库·sql·mysql
在努力的前端小白2 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
未来之窗软件服务2 小时前
自建知识库,向量数据库 (九)之 量化前奏分词服务——仙盟创梦IDE
数据库·仙盟创梦ide·东方仙盟·自建ai·ai分词
冒泡的肥皂5 小时前
MVCC初学demo(一
数据库·后端·mysql
.Shu.6 小时前
Redis Reactor 模型详解【基本架构、事件循环机制、结合源码详细追踪读写请求从客户端连接到命令执行的完整流程】
数据库·redis·架构
薛晓刚9 小时前
当MySQL的int不够用了
数据库
SelectDB技术团队9 小时前
Apache Doris 在菜鸟的大规模湖仓业务场景落地实践
数据库·数据仓库·数据分析·apache doris·菜鸟技术