当前位置: 首页 > news >正文

PostGreSQL模式schema

问题引入

        之前在做数据库设计时,经常会忽略schema模式,直接在数据库下的public模式下建立各类数据表。如果数据表命名不够规范,后期寻找某张表时就会比较麻烦。通过   所幸,PostgreSQL 的模式schema管理,可以对这个问题进行优化。

PGSQL-模式

模式schema

     模式(SCHEMA)可以看着是一个表的集合, 一个模式可以包含视图、索引、数据类型、函数和操作符等

        其实PG数据库提供的默认数据库模板就是按照模式schema对具备不同功能的数据表进行区分的,

postgres-模板数据库

        可以看到:相同的对象名称可以被用于不同的模式中而不会出现冲突,例如 public和 topology都可以包含名为 mytable 的表。虽然模式类似于操作系统层的目录,但是模式不能嵌套。

使用模式schema的优点

        使用模式的优势:

  • 允许多个用户使用一个数据库并且不会互相干扰。

  • 将数据库对象组织成逻辑组以便更容易管理。

  • 第三方应用的对象可以放在独立的模式中,这样它们就不会与其他对象的名称发生冲突。

        简单来讲,模式schema为了我们提供了一种按照某种业务规则管理数据表的便捷途径。

如何使用模式?

        ①创建模式:create schema schema_name

create schema myschema;

        ②在模式下创建数据表tb_user

create TABLE myschema.tb_user(user_id INTEGER NOT NULL,user_name VARCHAR(64) NOT NULL,pass_word VARCHAR(32) NOT NULL,create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,remark VARCHAR(128),PRIMARY KEY (user_id)
);

       接着指定主键user_id自增,需要为其创建自增序列:CREATE SEQUENCE,同样,我们的自增序列位于myschema模式下,

# 创建序列
CREATE SEQUENCE myschema.user_sequence START 1;
# 修改tb_user表的主键id为自增序列myschema.user_sequence
ALTER TABLE myschema.tb_user ALTER COLUMN user_id SET DEFAULT nextval('myschema.user_sequence'::regclass)

        ③在模式下创建视图:view_user

CREATE VIEW myschema.view_tb_user AS
SELECT user_id,user_name,create_time,remark FROM myschema.tb_user

         ④添加数据,验证ID主键自增以及create_time默认值是否生效,并通过视图查询数据,

INSERT INTO myschema.tb_user(user_name,pass_word,remark)
VALUES ('user_1',md5('123456'),'普通用户')

        查询视图,

SELECT * FROM myschema.view_tb_user

        ⑤删除模式:

情况1:删除一个模式以及其中包含的所有对象:

DROP SCHEMA myschema;

情况2:删除一个模式以及其中包含的所有对象:

DROP SCHEMA myschema CASCADE;

        如果直接删除myschema会报错, 

        我们使用级联删除,成功删除,

DROP SCHEMA myschema CASCADE

http://www.lryc.cn/news/209376.html

相关文章:

  • 大厂面试题-什么是JVM
  • rest参数
  • Hadoop3.0大数据处理学习3(MapReduce原理分析、日志归集、序列化机制、Yarn资源调度器)
  • JS DataTable中导出PDF中文乱码
  • 代码签名证书续费
  • 机器学习之ROC与AUC
  • 实用篇-Eureka注册中心
  • 基于springboot实现篮球竞赛预约平台管理系统项目【项目源码+论文说明】
  • OpenHarmony docker环境搭建所见的问题和解决
  • 1817_ChibiOS的RT线程
  • 牛客网刷题-(7)
  • 多模态领域的先进模型
  • 列表自动向上滚动
  • 嘴笨的技术人员怎么发言
  • vue源码分析(三)——new Vue 的过程(详解data定义值后如何获取的过程)
  • 软考系统架构师知识点集锦四:信息安全技术基础知识
  • Vscode中不显示.ipynb文件单元格行号
  • 【Oracle】[INS-30131]执行安装程序验证所需的初始设置失败。
  • 二进制部署kubernetes集群的推荐方式
  • 智能矩阵,引领商业新纪元!拓世方案:打破线上线下界限,开启无限营销可能!
  • ADB原理(第四篇:聊聊adb shell ps与adb shell ps有无双引号的区别)
  • 「网络编程」数据链路层协议_ 以太网协议学习
  • 通过python操作neo4j
  • Ubuntu中查看电脑有多少个核——lscpu
  • Python学习笔记第七十二天(Matplotlib imread)
  • 安卓核心板_天玑700、天玑720、天玑900_5G模块规格参数
  • CS224W2.2——传统基于特征的方法(边层级特征)
  • python—openpyxl操作excel详解
  • 汽车行驶性能的主观评价方法(2)-驾驶员的任务
  • server2012 通过防火墙开启局域网内限定IP进行远程桌面连接