Postgresql 基础使用语法

1.数据类型

1.数字类型

类型    长度     说明      范围    与其他db比较

Smallint 2字节 小范围整数类型 32768到+32767

integer 4字节 整数类型 2147483648到+2147483647

bigint 8字节 大范围整数类型 -9233203685477808到+9223203685477807

decimal 可变 用户指定 精度小数点前131072位;小数点后16383位

numeric 可变 用户指定 精度小数点前131072位;小数点后16383位

real 4字节 变长,不精确 6位十进制精度

double precision 8字节 变长,不精确 15位十进制精度

smallserial 2字节 smallint I自增序列 1到32767

serial 4字节 Integer自增序列 1到2147483647

bigserial 8字节 bigint自增序列 1到922372036854775807

money 8字节 金钱类型

  1. 字符类型

类型

长度

说明

varchar(n),character varying(n)

变长

字符最大数有限制

char(n),character(n)

定长

固定长度字符串字符数没达到最大值则使用空白填充

text

变长

无长度限制

  1. 日期时间

类型 长度 说明 范围 与其他db比较

  1. 基本操作

2.1数据库操作

//创建数据库

CREATE DATABASE 库名

//在创建数据库时指定参数信息 WITH OWNER:所有者 ENCODING:编码格式

CREATE DATABASE 库名 WITH OWNER = postgres ENCODING = ‘utf-8’

//修改数据库名称

ALTER DATABASE 旧库名 RENAME TO 新库名

//修改连接限制数

ALTER DATABASE 库名 CONNECTION LIMIT 20

//删除数据库

DROP DATABASE 库名

2.2表操作

//创建表

CREATE TABLE 表名(

字段1 类型1,

字段2 类型2

);

例:  

一,class_info表

create table class_info

(

    id                    serial not null

                          constraint class_info_pk

                          primary key,

    name                  varchar,

    write_date            timestamp

);

serial not null constraint student_pk primary key,

"serial" 列被设置为 "not null",并且有一个名为 "student_pk" 的主键约束。

主键的作用是确保表中的每个数据行都可以被唯一地标识,并且主键值不能重复或为空。在创建主键约束后,系统会自动检查插入的数据是否违反了主键的唯一性要求,如果有重复的主键值或缺少主键值,就会抛出错误,阻止插入操作。

comment on table student is '学生表'; comment on column student.name is '名称';

给名为 student 的表添加注释,注释内容为 '学生表',用于描述表的作用或用途。

-- id serial not null 表示id自增  -- id integer not null 表示id不自增

二,studen 表

create table student

(

    id                    serial not null

                          constraint student_pk 

                          primary key,

    name                  varchar,

    class_id             integer  references "class_info"("id"),    //references 外键

    height                numeric,

    weight                numeric,

    write_date            timestamp

);

//外键

外来键是一个(或数个)指向另外一个表格主键的栏位。

假设我们有两个表格:一个 CUSTOMER 表格,里面记录了所有顾客的资料;另一个 ORDERS 表格,里面记录了所有顾客订购的资料。在这里的一个限制,就是所有的订购资料中的顾客,都一定是要跟在 CUSTOMER 表格中存在。在这里,我们就会在 ORDERS 表格中设定一个外来键,而这个外来键是指向 CUSTOMER 表格中的主键。这样一来,我们就可以确定所有在 ORDERS 表格中的顾客都存在 CUSTOMER 表格中。换句话说,ORDERS表格之中,不能有任何顾客是不存在于 CUSTOMER 表格中的资料。

CUSTOMER 表格

栏位名

性质

SID

主键

Last_Name

First_Name

ORDERS 表格

栏位名

性质

Order_ID

主键

Order_Date

Customer_SID

外来键

Amount

2.3表操作

//修改表名

ALTER TABLE 旧表名 RENAME TO 新表名

//修改字段名

ALTER TABLE 表名 RENAME 旧字段 TO 新字段

//修改字段类型

ALTER TABLE 表名 ALTER COLUMN 字段 TYPE 类型(VARCHAR(40))

//删除字段

ALTER TABLE 表名 DROP COLUMN 字段

//添加字段

ALTER TABLE 表名 ADD COLUMN 字段 类型

//删除表

DROP TABLE 表名

//删除前进行判断

DROP TABLE IF EXISTS 表名

一般drop table if exists是数据库里面的,后面接表名如:drop table if exists xxx_book意思就是:如果数据库中存在xxx_book表,就把它从数据库中drop掉。

2.4往表中插入数据

//插入数据

INSERT INTO 表名 VALUES(1,'阿道夫','2022-10-10',NULL)

//指定字段插入数据

INSERT INTO 表名 (id,name) VALUES (‘2’,’王老五’);

批量导入

//将表数据插入到新表中

INSERT INTO 新表名 SELECT * FROM 表名;

//指定字段批量插入

INSERT INTO student1 (id,name) SELECT id, name FROM student;

往新表中插入其他表的指定字段数据

INSERT INTO employee (e_id, name) SELECT id, name FROM company WHERE name IS NOT NULL;

//往employee(e_id) 和 (name) 字段 插入 company表的 id name字段的值 如果name不为空的话

2.5 修改表数据

//更新数据,将id等于2的用户名改成'张三' ,如果不指定更新条件,会全局更新

UPDATE 表名 SET name = ‘张三 WHERE id = 2

2.6删除表数据

//删除id等于2的表数据

DELETE FROM 表名 WHERE id = 2

//删除id在1到3的表数据

DELETE FROM student WHERE id BETWEEN 1 and 3;

//清空数据表
DELETE from student;

TRUNCATE TABLE student;

2.7表查询

//查询所有字段内容

SELECT * FROM 表名

//批量字段查询

SELECT id, name FROM student;

//  多表查询

SELECT student.name, student1.name  FROM student;

//  给表取别名后查询,简化代码

SELECT s.id, s.name  FROM student s;

2.7.1单表指定条件查询

//in关键字查询 查询id为1,3,5的成员

SELECT id,name FROM 表名 WHERE id IN (1,3,5)

//between and 关键字查询,在什么之间

SELECT id,name,birthday FROM 表名 WHERE birthday BETWEEN '2020-10-10' AND '2024-10-10'

//模糊查询,查询所有姓张的用户

SElECT id, name FROM 表名 WHERE name LIKE ‘张%’

2.7.2单表指定条件复杂查询

//查询所有字段内容

SELECT * FROM student;

//只显示前3条数据

SELECT * FROM student LIMIT 3;

//查询三条数据,从第二条开始

SELECT * FROM student LIMIT 3 OFFSET 2;

//查询姓名非空内容

SELECT id,name FROM student where name is NOT null;

// 1 or 3 :1与3 ;ORDER BY id ASC 按id升序 ORDER BY id DESC 按id降序 默认升序

SELECT id,name FROM student where id=1 OR id=3 ORDER BY id ;

2.7.3 多表查询

//创建一个班级表,id为主键   id int PRIMARY KEY,

//创建学生表,id为主键,classid为外键,关联表class的id

CONSTRAINT pk_student_id FOREIGN KEY(classid) REFERENCES class(id)

//隐式内连接,关联classid显示student成员所在班级

SELECT student.id, class.id,student.name, class.name FROM student, class WHERE  student.classid = class.id;

//显示内连接,INNER JOIN不返回空值LEFT JOIN 左连接,RIGHT JOIN 右连接,不能匹配的数据也返回

//INNER JOIN,所以结果中只返回匹配的数据,不会有空值出现。

SELECT student.id, class.id,student.name, class.name

FROM student INNER JOIN class ON student.classid = class.id ;

例子:

SELECT c.id, c.name,c.address,e.huji,e.work_time,e.phone

FROM employee AS e

INNER JOIN company AS c ON e.e_id = c.id;

子查询

子查询或称为内部查询、嵌套查询,指的是在 PostgreSQL 查询中的 WHERE 子句中嵌入查询语句。

一个 SELECT 语句的查询结果能够作为另一个语句的输入值

//EXISTS关键字子查询

SELECT * FROM student WHERE EXISTS

(SELECT class.id FROM class WHERE class.name = '二班' AND student.classid = class.id);

//IN 关键字子查询

SELECT * FROM student WHERE student.classid IN

(SELECT class.id FROM class WHERE class.name = '二班' );

查询结果合并操作

UNION                 可去重复         执行速度慢

UNION ALL         不可去重复         执行速度快

  1. 运算符

  3.1算术运算符 +   -   *   %

3.2比较运算符 =   返回t f

3.3 逻辑运算符 NOT(逻辑非)  AND(逻辑与)  OR(逻辑或)

//判断2是否在1~3之间 T 

SELECT 2 BETWEEN 1 AND 3;

//判断2是否在234集合中 T

SELECT 2 in (2,3,4);

//like运算符模糊匹配 %代表多个字符  _代表一个字符

SELECT 'abc' LIKE 'a%', --T

 'abc' LIKE '_a_', --F

 'abc' LIKE '_b_', --T

 'abc' NOT LIKE '_b_'; --F

SELECT LEAST(1,2,3), --返回最小值:1

 GREATEST(1,2,3); --返回最大值:3

  1.  函数

4.1数值函数

SELECT 函数(字段名) from 表名;   !!!!!

4.2字符串函数

 SELECT 函数(字段名) from 表名;!!!!

4.3日期时间函数

CURRENT_DATA   = 2023-08-03

CURRENT_TIME   = 18:18:01.412198+08

NOW            = 2023-08-03 18:18:01.412198+08

EXTRACT使用 (相当于转换时间格式)

 

  1.  自定义函数

CREATE FUNCTION //声明创建函数

ADD(INTEGER,INTEGER) //定义函数名称

RETURNS INTEGER //定义函数返回值

AS'SELECT $1 + $2;' //定义函数体

LANGUAGE SQL //用以实现函数的语言名字

RETURNS NULL ON NULL INPUT;    //定义参数为NULL时处理情况

例子:

 

  1.  数据库索引

 

使用索引的优缺点

优点

通过创建唯一的索引,可以保证数据库表中每一行数据的唯一性。

可以大大提高查询速度

加速表与表之间的连接

减少查询中分组和排序的时间

缺点

创建和维护索引耗费时间,数据量越多耗费的时间越多

索引需要占用物理空间

对表的数据进行增加、删除、修改的时候,索引也需要动态维护,降低了数据的维护速度。

//-- 创建索引 此处默认使用B-tree

CREATE INDEX student_name_index ON student(name);

//-- 删除索引

DROP INDEX student_name_index;

  1.  数据库视图

使用视图具有 简单化、安全性、逻辑数据独立性

--创建视图top3,展示id,name,birthday 条件是id<=3  并且按id降序

CREATE VIEW top3 AS SELECT id,name,birthday FROM student where id <= 3 ORDER BY id desc;

--查看视图

SELECT * FROM top3;

--删除视图

 

DROP VIEW top3;

  1.  主键` 外键

主键 使用PRIMARY KEY语句设置为主键

外键 CONSTRAINT pk_student_id FOREIGN KEY(classid) REFERENCES class(id)  关联其他表的主键

  1.  约束

主键与约束的区别,主键的值是非空唯一,且一个表只能有一个主键,可以有多个约束

    1. // UNIQUE 唯一约束
    2. // NOT NULL 非空约束
    3. // DEFAULT 默认值约束

例子:

CREATE TABLE student(

id INT UNIQUE,     // UNIQUE 唯一约束

name VARCHAR(30) NOT NULL,  // NOT NULL 非空约束

birthday DATE,

score NUMERIC(5,2) DEFAULT 0.0  // DEFAULT 默认值约束

);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/74520.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

前端基础(二)

前言&#xff1a;前端开发框架——Vue框架学习。 准备工作&#xff1a;添加Vue devtools扩展工具 具体可查看下面的这篇博客 添加vue devtools扩展工具添加后F12不显示Vue图标_MRJJ_9的博客-CSDN博客 Vue官方学习文档 Vue.js - 渐进式 JavaScript 框架 | Vue.js MVVM M…

基于dbn+svr的交通流量预测,dbn详细原理

目录 背影 DBN神经网络的原理 DBN神经网络的定义 受限玻尔兹曼机(RBM) DBN+SVR的交通流量预测 基本结构 主要参数 数据 MATALB代码 结果图 展望 背影 DBN是一种深度学习神经网络,拥有提取特征,非监督学习的能力,是一种非常好的分类算法,本文将DBN+SVR用于交通流量预测…

86. 分隔链表

86. 分隔链表 题目-中等难度示例1. 新建两链表&#xff0c;根据x值分类存放&#xff0c;最后合并 题目-中等难度 给你一个链表的头节点 head 和一个特定值 x &#xff0c;请你对链表进行分隔&#xff0c;使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。 你应当 保…

verilog学习笔记5——进制和码制、原码/反码/补码

文章目录 前言一、进制转换1、十进制转二进制2、二进制转十进制3、二进制乘除法 二、原码、反码、补码1、由补码计算十进制数2、计算某个负数的补码 前言 2023.8.13 天气晴 一、进制转换 1、十进制转二进制 整数&#xff1a;除以2&#xff0c;余数倒着写 小数&#xff1a;乘…

redis数据类型详解+实例

redis中的数据类型&#xff1a; string&#xff0c;list, set, zset, hash,bitmaps, hyperloglog, gepspatial 目录 一、 String 二、List 三、Set 四、Zset 五、Hash 六、Bitmaps 七、Hyperloglog 八、Gepspatial 一、 String redis最基本的数据类型&#xff0c;一个…

超级品牌,都在打造数据飞轮

更多技术交流、求职机会&#xff0c;欢迎关注字节跳动数据平台微信公众号&#xff0c;回复【1】进入官方交流群 引入 「收钱吧到账15元。」 从北京大栅栏的糖葫芦铺子&#xff0c;到南京夫子庙的鸭血粉丝汤馆&#xff0c;再到广州珠江畔的早茶店&#xff0c;不知不觉间&#xf…

腾讯云国际站代充-阿里云ECS怎么一键迁移到腾讯云cvm?

今天主要来介绍一下如何通过阿里云国际ECS控制台一键迁移至腾讯云国际CVM。腾讯云国际站云服务器CVM提供全面广泛的服务内容。无-需-绑-定PayPal&#xff0c;代-充-值腾讯云国际站、阿里云国际站、AWS亚马逊云、GCP谷歌云&#xff0c;官方授权经销商&#xff01;靠谱&#xff0…

白帽黑帽与linux安全操作

目录 白帽黑帽 Linux安全 白帽黑帽 白帽&#xff08;White Hat&#xff09;和黑帽&#xff08;Black Hat&#xff09;通常用于描述计算机安全领域中的两种不同角色。白帽黑客通常被认为是合法的安全专家&#xff0c;他们通过合法途径寻找和修复安全漏洞&#xff0c;帮助企业和…

使用路由器更改设备IP_跨网段连接PLC

在一些设备IP已经固定,但是需要采集此设备的数据,需要用到跨网段采集 1、将路由器WAN&#xff08;外网拨号口&#xff09;设置为静态IP 2、设置DMZ主机&#xff0c;把DMZ主机地址设置成跨网段的PLC地址 DMZ主机 基本信息. DMZ (Demilitarized Zone)即俗称的非军事区&#xff0…

第5章:神经网络

神经元模型 上述定义的简单单元即为神经元模型。 多层网络 误差逆传播算法 标准BP算法&#xff1a;参数更新非常频繁&#xff0c;可能出现抵消现象。积累BP算法&#xff1a;下降到一定程度上&#xff0c;进行下一步会非常缓慢。 过拟合 早停&#xff1a;划分训练集和验证集…

小视频AI智能分析系统解决方案

2022下半年一个项目&#xff0c;我司研发一个基于接收小视频录像文件和图片进行算法分析抓拍的系统&#xff0c;整理了一下主要思想如下&#xff1a; 采用C开发一个AI识别服务&#xff0c;该服务具有如下功能: 创建各类算法模型服务引擎池&#xff0c;每类池内可加载多个模型…

TCP消息传输可靠性保证

TCP链接与断开 -- 三次握手&四次挥手 三次握手 TCP 提供面向有连接的通信传输。面向有连接是指在数据通信开始之前先做好两端之间的准备工作。 所谓三次握手是指建立一个 TCP 连接时需要客户端和服务器端总共发送三个包以确认连接的建立。在socket编程中&#xff0c;这一…

计算机组成原理之地址映射

例1&#xff1a;某计算机主存容量256MB&#xff0c;按字编址&#xff0c;字长1B&#xff0c;块大小32B&#xff0c;Cache容量512KB。对如下的直接映射方式、4-路组相联映射方式、全相联映射方式的内存地址格式&#xff0c;求&#xff1a; &#xff08;1&#xff09;计算A、B、C…

05 - 研究 .git 目录

查看所有文章链接&#xff1a;&#xff08;更新中&#xff09;GIT常用场景- 目录 文章目录 1. HEAD2. config3. refs4. objects 1. HEAD 2. config 3. refs 4. objects Git对象一共有三种&#xff1a;数据对象 blob、树对象 tree以及提交对象 commit&#xff0c;这些对象都被保…

详谈数据库InnoDB引擎与MyISAM引擎

目录 1. 简单了解什么是存储引擎? 2. InnoDB 引擎概述 3. MyISAM 引擎概述 4. InnoDB 与 MyISAM 的一些区别 1. 简单了解什么是存储引擎? 相信很多人在听到存储引擎这个名字的时候可能会有些疑惑&#xff0c;听着名字就觉得有些难&#xff0c;导致很多人没有兴趣了解它&a…

使用基于jvm-sandbox的对三层嵌套类型的改造

使用基于jvm-sandbox的对三层嵌套类型的改造 问题背景 先简单介绍下基于jvm-sandbox的imock工具&#xff0c;是Java方法级别的mock&#xff0c;操作就是监听指定方法&#xff0c;返回指定的mock内容。 jvm-sandbox 利用字节码操作和自定义类加载器的技术&#xff0c;将原始方法…

el-table实现静态和动态合并单元格 以及内容显示的问题

实现效果图 <el-tablev-loading"loading":data"tableData"style"width: 100%":row-class-name"tableRowClassName"size"small"><el-table-column fixed label"序号" width"50"><el-tab…

文本分类实战-NLP

数据集及任务分析 项目主题&#xff1a;新闻的主题分类&#xff0c;10分类任务 一般对于NLP项目来说的话需要进行数据预处理的&#xff0c;但是由于本项目的数据是经过处理过的&#xff0c;所以就不需要进行数据预处理了&#xff0c;但是数据预处理对NLP项目是重中之重的。 TH…

【Linux】高级IO

目录 IO的基本概念 钓鱼五人组 五种IO模型 高级IO重要概念 同步通信 VS 异步通信 阻塞 VS 非阻塞 其他高级IO 阻塞IO 非阻塞IO IO的基本概念 什么是IO&#xff1f; I/O&#xff08;input/output&#xff09;也就是输入和输出&#xff0c;在著名的冯诺依曼体系结构当中…

Python-OpenCV中的图像处理-视频分析

Python-OpenCV中的图像处理-视频分析 视频分析Meanshift算法Camshift算法光流 视频分析 学习使用 Meanshift 和 Camshift 算法在视频中找到并跟踪目标对象: Meanshift算法 Meanshift 算法的基本原理是和很简单的。假设我们有一堆点&#xff08;比如直方 图反向投影得到的点&…