当前位置: 首页 > 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…...

KubeSphere 容器平台高可用:环境搭建与可视化操作指南

Linux_k8s篇 欢迎来到Linux的世界,看笔记好好学多敲多打,每个人都是大神! 题目:KubeSphere 容器平台高可用:环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...

基于算法竞赛的c++编程(28)结构体的进阶应用

结构体的嵌套与复杂数据组织 在C中,结构体可以嵌套使用,形成更复杂的数据结构。例如,可以通过嵌套结构体描述多层级数据关系: struct Address {string city;string street;int zipCode; };struct Employee {string name;int id;…...

RocketMQ延迟消息机制

两种延迟消息 RocketMQ中提供了两种延迟消息机制 指定固定的延迟级别 通过在Message中设定一个MessageDelayLevel参数,对应18个预设的延迟级别指定时间点的延迟级别 通过在Message中设定一个DeliverTimeMS指定一个Long类型表示的具体时间点。到了时间点后&#xf…...

渗透实战PortSwigger靶场-XSS Lab 14:大多数标签和属性被阻止

<script>标签被拦截 我们需要把全部可用的 tag 和 event 进行暴力破解 XSS cheat sheet&#xff1a; https://portswigger.net/web-security/cross-site-scripting/cheat-sheet 通过爆破发现body可以用 再把全部 events 放进去爆破 这些 event 全部可用 <body onres…...

CocosCreator 之 JavaScript/TypeScript和Java的相互交互

引擎版本&#xff1a; 3.8.1 语言&#xff1a; JavaScript/TypeScript、C、Java 环境&#xff1a;Window 参考&#xff1a;Java原生反射机制 您好&#xff0c;我是鹤九日&#xff01; 回顾 在上篇文章中&#xff1a;CocosCreator Android项目接入UnityAds 广告SDK。 我们简单讲…...

虚拟电厂发展三大趋势:市场化、技术主导、车网互联

市场化&#xff1a;从政策驱动到多元盈利 政策全面赋能 2025年4月&#xff0c;国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》&#xff0c;首次明确虚拟电厂为“独立市场主体”&#xff0c;提出硬性目标&#xff1a;2027年全国调节能力≥2000万千瓦&#xff0…...

免费数学几何作图web平台

光锐软件免费数学工具&#xff0c;maths,数学制图&#xff0c;数学作图&#xff0c;几何作图&#xff0c;几何&#xff0c;AR开发,AR教育,增强现实,软件公司,XR,MR,VR,虚拟仿真,虚拟现实,混合现实,教育科技产品,职业模拟培训,高保真VR场景,结构互动课件,元宇宙http://xaglare.c…...

热门Chrome扩展程序存在明文传输风险,用户隐私安全受威胁

赛门铁克威胁猎手团队最新报告披露&#xff0c;数款拥有数百万活跃用户的Chrome扩展程序正在通过未加密的HTTP连接静默泄露用户敏感数据&#xff0c;严重威胁用户隐私安全。 知名扩展程序存在明文传输风险 尽管宣称提供安全浏览、数据分析或便捷界面等功能&#xff0c;但SEMR…...

GeoServer发布PostgreSQL图层后WFS查询无主键字段

在使用 GeoServer&#xff08;版本 2.22.2&#xff09; 发布 PostgreSQL&#xff08;PostGIS&#xff09;中的表为地图服务时&#xff0c;常常会遇到一个小问题&#xff1a; WFS 查询中&#xff0c;主键字段&#xff08;如 id&#xff09;莫名其妙地消失了&#xff01; 即使你在…...

「Java基本语法」变量的使用

变量定义 变量是程序中存储数据的容器&#xff0c;用于保存可变的数据值。在Java中&#xff0c;变量必须先声明后使用&#xff0c;声明时需指定变量的数据类型和变量名。 语法 数据类型 变量名 [ 初始值]; 示例&#xff1a;声明与初始化 public class VariableDemo {publi…...