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

postgresql14-表的管理(四)

表table

创建表

CREATE TABLE table_name --表名
(column_name data_type column_constraint, --字段名、字段类型、约束字段(可选)column_name data_type, --表级别约束字段...,table_constraint
);
CREATE TABLE emp1 --创建表
AS
SELECT * FROM employees; --携带数据导入
-- WHERE 1=0; 不携带数据导入
SELECT *
INTO emp2
FROM employees;

字段类型举例

1、字符类型:定长字符串CHAR(n)、变长字符串VARCHAR(n),更大长度的字符串TEXT;
2、数字类型:整数类型SMALLINT、INTEGER、BIGINT,精确数字NUMERIC (p, s),浮点数 REAL、DOUBLE PRECISION;
3、时间类型:日期 DATE、时间TIME、时间戳TIMESTAMP;


/*
举例:表名departments
部门编号department_id,整型,非空,表的主键
部门名称department_name,字符串,可变长度,非空
*/
CREATE TABLE departments( department_id INTEGER NOT NULL PRIMARY KEY, department_name CHARACTER VARYING(30) NOT NULL) ;

约束

1、NOT NULL:非空约束,该字段的值不能为空(NULL);

2、UNIQUE:唯一约束,该字段每一行的值不能重复。注意:PostgreSQL允许该字段存在
多个 NULL 值,并且将其看作不同的值。但SQL标准只允许UNIQUE字段中存在一个 NULL 值;

3、PRIMARY KEY:主键约束,包含 NOT NULL 约束和 UNIQUE 约束。注意:如果主键只包
含一个字段,可以通过列级约束进行定义;如果主键包含多个字段(复合主键)或者需要为主键指定一个自定义的名称,需要使用表级约束进行定义;

4、REFERENCES:外键约束,字段中的值必需已经在另一个表中存在。外键用于定义两
个表之间的参照完整性(referential integrity),例如:员工的部门编号字段必须是一个
已经存在的部门;

5、CHECK:检查约束,插入或更新数据时检查数据是否满足某个条件。例如,产品的价
格必需大于零;

6、DEFAULT:默认值,插入数据时,如果没有为这种列指定值,系统将会使用默认值代替;

--举例
CREATE TABLE employees( employee_id INTEGER NOT NULL, first_name CHARACTER VARYING(20), last_name CHARACTER VARYING(25) NOT NULL, email CHARACTER VARYING(25) NOT NULL, phone_number CHARACTER VARYING(20), hire_date DATE NOT NULL, salary NUMERIC(8,2), commission_pct NUMERIC(2,2), manager_id INTEGER, department_id INTEGER, CONSTRAINT emp_emp_id_pkPRIMARY KEY (employee_id), CONSTRAINT emp_salary_minCHECK (salary > 0) , CONSTRAINT emp_email_ukUNIQUE (email), CONSTRAINT emp_dept_fkFOREIGN KEY (department_id)REFERENCES departments(department_id), CONSTRAINT emp_manager_fkFOREIGN KEY (manager_id)REFERENCES employees(employee_id)) ;

模式搜索

CREATE TABLE schema_name.table_name; --创建表的完整语法
SHOW search_path; --查看搜索路径,返回参数:当前用户、模式

在这里插入图片描述

--修改默认的搜索路径
SET search_path=hr,public --先在hr模式中操作,后在public模式中操作--比如
CREATE TABLE ceshibiao (id int);

在这里插入图片描述

修改表

查看

\d 表名

添加字段

-- 添加字段格式
ALTER TABLE table_name
ADD COLUMN column_name data_type column_constraint;--如果没有default值,新增字段默认使用null值
ALTER TABLE products ADD COLUMN description text;
--新增字段指定默认值
ALTER TABLE products ADD COLUMN notes text DEFAULT 'new product' not 
null;

删除字段

--删除字段,同时删除数据、索引、约束,但是对象引用(外键引用、视图、存储过程)不会删除
ALTER TABLE table_name DROP COLUMN column_name;--假设departments 表的 department_id 是 employees 表的外键引用列,无法直接删除
--级联删除格式
ALTER TABLE departments DROP COLUMN department_id CASCADE;

添加约束

--添加约束
ALTER TABLE table_name ADD table_constraint;-- 添加检查约束
ALTER TABLE products ADD CONSTRAINT products_price_min CHECK (price > 0);
-- 添加唯一约束
ALTER TABLE products ADD CONSTRAINT products_name_uk UNIQUE (name);-- 添加非空约束格式
ALTER TABLE table_name ALTER COLUMN column_name SET NOT NULL;

删除约束

-- 删除约束格式
--RESTRICT为默认值,如果存在其他依赖于该约束的对象,需要使用CASCADE执行级联删除
ALTER TABLE table_name DROP CONSTRAINT constraint_name [ RESTRICT | CASCADE ]--删除非空约束
ALTER TABLE table_name ALTER COLUMN column_name DROP NOT NULL;

字段类型转换

--转换字段数据类型
--隐式转换:已有数据能兼容新数据类型
ALTER TABLE table_name ALTER COLUMN column_name TYPE new_data_t;--将产品表的 price 字段的类型修改为numeric(10,2)
ALTER TABLE products ALTER COLUMN price TYPE numeric(10,2);
--显式转换,使用USING
ALTER TABLE table_name ALTER COLUMN column_name TYPE new_data_type USING
expression--增加一个可变字符串类型的字段level
ALTER TABLE products ADD COLUMN level VARCHAR(10);
--隐式报错
ALTER TABLE products ALTER COLUMN level TYPE INTEGER;
ERROR: column "level" cannot be cast automatically to type integer
HINT: You might need to specify "USING level::integer".--改为显式转换
ALTER TABLE products ALTER COLUMN level TYPE INTEGER USING level::integer

重命名字段

ALTER TABLE table_name
RENAME COLUMN column_name TO new_column_name;
--举例
ALTER TABLE products
RENAME COLUMN product_no TO product_number

重命名表

ALTER TABLE table_name
RENAME TO new_name;
--举例
ALTER TABLE products
RENAME TO items;

删除表

--如果使用了 IF EXISTS,删除一个不存在的表不会产生错误
DROP TABLE [ IF EXISTS ] name [ CASCADE | RESTRICT ]

相关文章:

postgresql14-表的管理(四)

表table 创建表 CREATE TABLE table_name --表名 (column_name data_type column_constraint, --字段名、字段类型、约束字段(可选)column_name data_type, --表级别约束字段...,table_constraint );CREATE TABLE emp1 --创建表 AS SELECT * FROM empl…...

Java--Object类

Java中Object类是所有类的父类,是Java中最高层的类。用户创建一个类时,除非指定继承了某个类,否则都是继承于Object类。 由于所有类都继承于Object类,所以所有类都可以重写Object类中的方法。但是Object类中被final修饰的getClass…...

交换机端口灯常亮 端口up状态 服务器设置ip交换机获取不到服务器网卡mac地址 不能通信

环境: 深信服防火墙 8.0.75 AF-2000-FH2130B-SC S6520X-24ST-SI交换机 version 7.1.070, Release 6530P02 问题描述: 交换机一个vlan下有3台服务器,连接端口2、3、4,2和3连接的服务器正常,交换机3端口灯常亮 端口up状态 服务器自动获取不了地址,改为手动设置ip后,交…...

Linux笔记之diff和vimdiff

Linux笔记之diff和vimdiff code review! 文章目录 Linux笔记之diff和vimdiff一.diff1.1.使用diff比较文件夹1.2.使用diff比较文件1.4.colordiff——带颜色输出差异 二.vimdiff2.1.vimdiff颜色差异2.2.vimfiff调整栏宽2.3.修改颜色变谈,使代码可以看清楚2.4.vimdif…...

目标检测YOLO实战应用案例100讲-基于改进的YOLOV5算法的垃圾分类模型

目录 前言 国内外研究现状 目标检测算法发展现状 YOLO算法的发展现状...

我做不到受每个人喜欢

我做不到受每个人喜欢 我想描述一下昨天发生争吵后我个人的观点,希望能够重新呈现出一种积极的态度。 首先,让我简要梳理一下事件的经过,当天我像往常一样去另一个宿舍找人聊天,可能因为说话声音有点大,坐在我后面的那…...

Linux笔记之diff工具软件P4merge的使用

Linux笔记之diff工具软件P4merge的使用 code review! 文章目录 Linux笔记之diff工具软件P4merge的使用1.安装和配置2.使用:p4merge a.cc b.cc3.配置git 参考博文: Ubuntu Git可视化比较工具 P4Merge 的安装/配置及使用 1.安装和配置 $ wget https://cdist2.per…...

使用 OpenSSL 扩展来实现公钥和私钥加密

首先,你需要生成一对公钥和私钥。可以使用 OpenSSL 工具来生成: 1、生成私钥 openssl genpkey -algorithm RSA -out private_key.pem 2、从私钥生成公钥: openssl rsa -pubout -in private_key.pem -out public_key.pem现在你有了一个私钥…...

二、安全与风险管理—安全与风险管理基础

目录 目录 1.什么是信息与信息的生命周期 2.信息安全的基本目标 3.风险管理与控制类型...

rust学习——栈、堆、所有权

文章目录 栈、堆、所有权栈(Stack)与堆(Heap)栈堆性能区别所有权与堆栈 所有权原则变量作用域所有权与函数返回值与作用域 栈、堆、所有权 栈(Stack)与堆(Heap) 栈和堆是编程语言最核心的数据结构,但是在很多语言中,你并不需要深入了解栈与堆。 但对于…...

如何从小白成长为AI工程师笔记

📚入门机器学习基础 对于本科生来说,需要打好数学基础,包括高数、概率论和线性代数。 对于已经上研究生或工作想转行的人来说,可以直接开始学习机器学习算法,重要的是理解算法的原理和推导过程。如果有时间和需要&am…...

fail-fast 和 fail-safe 迭代器

fail-fast 和 fail-safe 迭代器是两种不同的迭代器设计策略,用于在遍历集合(如 ArrayList、HashMap)时处理并发修改的情况。它们的行为和应对策略有所不同: Fail-Fast 迭代器: Fail-Fast 迭代器在遍历集合期间&#x…...

Nvidia显卡基础概念介绍

一、PCIe与SXM 1.1 Nvidia GPU PCIe PCIe(peripheral component interconnect express)是一种高速串行计算机扩展总线标准,是英特尔公司在2001年提出来的,它的出现主要是为了取代AGP接口,优点就是兼容性比较好,数据传输速率高、…...

使用screen实现服务器代码一直运行

1.安装screen sudo apt install screen 2.创建一个screen(创建一个名为chatglm的新的链接,用来一直运行 screen -S chatglm 3.查看进程列表 screen -ls 创建之后,就可以在当前窗口利用cd命令进入要执行的项目中,开始执行&#xf…...

Linux系统自有服务

一、Linux中防火墙firewalld 1、什么是防火墙 防火墙:防范一些网络攻击。有软件防火墙、硬件防火墙之分。 防火墙选择让正常请求通过,从而保证网络安全性。 Windows防火墙: Windows防火墙的划分与开启、关闭操作: 2、防火墙的作…...

Andriod学习笔记(二)

页面设计的零碎知识 通用属性设置文本大小设置视图宽高设置视图的对齐方式 页面布局LinearLayoutRelativeLayoutGridLayoutScollView 按钮触控ButtonImageViewImageButton 通用属性 设置文本大小 纯数字的setTextSize方法,内部默认字体单位为sp,sp是An…...

【超级基础版】十进制与二进制的转换

目录 一、为什么是二进制? 二、二进制的加法和乘法 三、二进制向十进制转换 四、十进制整数向二进制转换 五、十进制小数向二进制小数的转换 六、八进制和十六进制的引入 一、为什么是二进制? 我们知道电脑的数据本质上是0和1,就是我们…...

爬虫学习日记第八篇(爬取fofa某端口的协议排行及其机器数目,统计top200协议)

需求 找到最常用的200个协议 通过fofa搜索端口,得到协议排名前五名和对应机器的数目。 遍历端口,统计各个协议对应的机器数目(不准,但能看出个大概) 读写API API需要会员,一天只能访问1000次。 import…...

LeetCode 1425. 带限制的子序列和【动态规划,单调队列优化】2032

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章…...

强化学习问题(7)--- Python和Pytorch,Tensorflow的版本对应

1.问题 之前下载的python3.8,在对应Pytorch和Tensorflow时没太在意版本,在运行一些代码时,提示Pytorch和Tensorflow版本过高,直接降下来,有时候又和Python3.8不兼容,所以又在虚拟环境搞一个Pyhon3.7&#x…...

立知-lychee-rerank-mm详细步骤:日志排查、重启、调试全流程

立知-lychee-rerank-mm详细步骤:日志排查、重启、调试全流程 1. 引言:当重排序模型“罢工”时 想象一下这个场景:你正在搭建一个智能问答系统,用户上传了一张“金毛犬在草地上奔跑”的图片,并问“这是什么品种的狗&a…...

Kalibr实战指南:从零完成双目相机与IMU的高精度联合标定

1. 为什么需要双目相机与IMU联合标定? 在机器人导航、自动驾驶等应用中,多传感器融合是提升系统精度的关键。双目相机能提供丰富的视觉信息,IMU(惯性测量单元)则能输出高频的运动数据。但要让它们协同工作,…...

实验拓扑作业

LSW3 配置为二层 Trunk,透传所有 VLAN LSW1/LSW2 配置 VLANIF 接口,分别创建两组 VRRP 实现主备 三台交换机配置 MSTP,将 VLAN10、VLAN20 映射到不同实例,指定不同根桥 配置静态 / 动态路由,实现网关到 AR1 的外网连通…...

D3KeyHelper终极指南:5分钟掌握暗黑3技能自动化神器

D3KeyHelper终极指南:5分钟掌握暗黑3技能自动化神器 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper 想要彻底解放双手,让暗黑…...

响应式编程-Flux 背压机制与操作符链式调用源码解析

1. 响应式编程与背压机制基础 第一次接触响应式编程时,我被它的"数据流"概念深深吸引。想象一下,数据就像水管中的水流,而背压机制就是水管上的阀门控制——当水压过大时自动调节流量,防止爆管。这种设计完美解决了异步…...

Windows环境下IDEA集成Java与Protobuf的高效开发指南

1. 环境准备:Protobuf与IDEA的安装配置 在Windows系统下搭建Java与Protobuf的开发环境,就像组装一台高性能电脑——每个部件都要选对型号、正确安装。我经历过无数次环境配置的翻车现场,这里把最稳妥的配置方案分享给你。 首先去Protobuf的…...

惠普OMEN游戏本终极性能优化指南:OmenSuperHub开源工具完整教程

惠普OMEN游戏本终极性能优化指南:OmenSuperHub开源工具完整教程 【免费下载链接】OmenSuperHub 使用 WMI BIOS控制性能和风扇速度,自动解除DB功耗限制。 项目地址: https://gitcode.com/gh_mirrors/om/OmenSuperHub 还在为惠普OMEN游戏本官方软件…...

window环境下使用类似tail的命令跟踪滚动的日志

可以,而且有好几种方法,Windows 上完全能实现类似 Linux tail -f 滚动看日志的效果。1)最简单:PowerShell 自带(不用装软件)实时滚动刷新日志:powershellGet-Content app.log -Wait -Tail 20-Wa…...

[精品]基于微信小程序的宿舍报修系统的设计与实现 UniApp

收藏关注不迷路!!需要的小伙伴可以发链接或者截图给我 这里写目录标题项目介绍项目实现效果图所需技术栈文件解析微信开发者工具HBuilderXuniappmysql数据库与主流编程语言登录的业务流程的顺序是:毕设制作流程系统性能核心代码系统测试详细视…...

Agent评测体系:如何量化Agent的能力与可靠性

会根据问题选择召回策略、决定是否多次搜索、过滤重复结果,还能将高价值信息回写知识图谱库。 Agentic RAG 在普通RAG(“召回-增强-生成”)基础上更具主动性: 相比自然语言回答,精准性和可复现性更高,但对执行环境要求高,需在隔离…...