pgsql专题

【PL/pgSQL】华为数据库GaussDB及PostgreSQL 数据库系统的过程语言

文章目录 介绍 PL/pgSQL为什么选择 PL/pgSQL?基本语法和结构1. 基本结构2. 变量声明3. 控制结构4. 循环 存储过程与函数1. 创建存储过程2. 调用存储过程3. 自定义函数 触发器1. 创建触发器函数2. 创建触发器 异常处理高级语法特性示例控制结构条件语句循环 异常处理游标动态 SQL复合类型 实际应用案例案例 1:自动生成报告案例 2:复杂的数据迁移案例 3:

pgsql 取消id绑定索引 pgsql 删除序列

pgsql 取消id绑定索引 pgsql 删除序列 – pgsql 取消id绑定索引 alter table "t_student"alter column "id" drop default; – pgsql 删除序列 drop sequence if exists "t_student_seq"; – 删除序列 删除不了用这个 drop sequence t_studen

mybatis动态传参pgsql日期Interval

在navicat16中,标准写法 SELECT * FROM business_status_info WHERE create_time > (NOW() - INTERVAL '5  minutes')  在mybatis中,错误写法 SELECT * FROM business_status_info WHERE create_time > (NOW() - INTERVAL

pgsql中表名或者修改字段

批量修改表名或字段 ----------修改大小写begin------------创建方法修改表字段的大小写CREATE OR REPLACE FUNCTION "public"."exec"("sqlstring" varchar)RETURNS "pg_catalog"."varchar" AS $BODY$declareres varchar(50);BEGINEXECU

postgres数据库报错无法写入文件 “base/pgsql_tmp/pgsql_tmp215574.97“: 设备上没有空间

解决思路: base/pgsql_tmp下临时表空间不够 需要新建一个临时表空间指定到根目录之外的其他目录 并且修改默认临时表空间参数 解决方法: select * from pg_settings where name = 'temp_tablespaces';mkdir /home/postgres/tbs_tmpCREATE TABLESPACE tbs_tmp LOCATION '/

postgresql/pgsql如何抛出具体哪一行错误

1.如何抛出具体哪一行的错误,在oracle里面,可以用dbms_utility.format_error_backtrace打印具体的错误行号, 在pgsql里面,怎么打印呢? do$$declarev_num int ;v_text1 text;v_text2 text;beginv_num:=1/0;exception when othersthen get stacked

pgsql

创建分区表: PostgreSQL分区表_pg分区表-CSDN博客 创建list分区的函数 create or replace function create_list_fq(tb_name char, row_name char)returns intAS $$declares char;beginraise notice 'CREATE TABLE if not exists %_

Kettle (五):Kettle做定时任务将pgsql导入oracle

一、实现功能 Kettle实现定时更新的,从而,可以定时从pgsql中抽取数据到oracle。 二、环境 1.kettle8.0 2.oracle12c 三、新建pgsql到oracle转换 1.新建一个转换settime_transfer.ktr   2.其中表输入是pgsql的student_de表 3.插入更新模块 4.新建settime.job (1)拖入相关组件 (

pgsql的存储过程中$$ 和$dbvis$有什么区别

在PostgreSQL中,存储过程中的$ 和 和 和dbvis$是用于定义PL/pgSQL代码块的不同语法形式。具体来说: 1、$$:通常用于创建函数或存储过程时,定义PL/pgSQL代码块的开始和结束。这种语法要求在创建函数或存储过程时,将整个PL/pgSQL代码块包含在两个$$符号之间。这是创建函数或存储过程时最常见的用法。2、$dbvis$:是一种特殊的代码块语法,用于DBVIS(数据库

pgsql查看指定模式的存储过程

pgsql查看指定模式的存储过程 在 PostgreSQL 中,如果你想要查看指定模式的存储过程(也称为函数),你可以使用 \df 或 \df+ 命令在 psql 命令行工具中,或者使用 SQL 查询来从 pg_catalog 系统模式中查询。 \df命令行查询 请注意,\df 命令是 psql 的元命令,不是标准的 SQL 命令。这意味着它只能在 psql 命令行工具中使用,而不能在其他数

pgsql和mysql比较

pgsql相对于mysql的优势主要体现在以下几个方面: 稳定性和可靠性:PostgreSQL的稳定性极强,即使在崩溃、断电等灾难场景下也能表现出很好的抗打击能力。相比之下,很多MySQL用户都遇到过Server级的数据库丢失的情况。此外,PostgreSQL的主备复制属于物理复制,数据的一致性更加可靠,复制性能更高。12 性能和扩展性:在高并发读写和负载逼近极限的情况下,PostgreSQL的

Spring Boot中判断轨迹数据是否经过设置的打卡点,且在PGSQL中把点拼接成线,判断某个点是否在线上或在线的50米范围内

问题描述 轨迹数据判断是否经过打卡点,轨迹数据太多,循环判断的话非常消耗内存。解决办法只需要把所有轨迹数据点拼成了一条线,然后只需要循环打卡点即可,打卡点不多,一般不会超过100个,如果多的话,另说。。一般也就几个,也就是说有多少个打卡点就需要循环多少次,打卡点少,我们就可以使用循环去判断打卡点是否在线的范围内即可 数据结构 轨迹数据,每一条数据都是一个点 打卡点,一个范围内设置6个打

在PostgreSQL中如何创建和使用自定义函数,包括内置语言(如PL/pgSQL)和外部语言(如Python、C等)?

文章目录 一、使用内置语言 PL/pgSQL 创建自定义函数示例代码使用方法 二、使用外部语言 Python 创建自定义函数安装 PL/Python 扩展示例代码使用方法 三、使用外部语言 C 创建自定义函数编写 C 代码编译为共享库在 PostgreSQL 中注册函数注意事项 总结 PostgreSQL 是一个强大的开源关系型数据库管理系统,它支持用户创建自定义函数来扩展其

windows部署pgsql

1、下载:Download PostgreSQL Binaries 2、创建data目录作为数据目录 3、初始化 bin目录执行命令:  .\initdb.exe -D  E:\pgsql\data  -E UTF-8 --locale=chs -U postgres -W 输入密码直到完成 4、启动数据库  .\pg_ctl.exe -D  E:\pgsql\data

【PowerDesigner】PGSQL反向工程过程已中断

问题 反向工程过程已中断,原因是某些字符无法通过ANSI–>UTF-16转换进行映射。pg导入sql时报错,一查询是power designer 反向工程过程已中断,某些字符无法通过ANSI–>UTF-16转换进行映射(会导致数据丢失) 处理 注释说明 tab.name = tab.comment +"("+tab.code+")"col.name= col.comment +"("

pgsql 时间线

PGSql时间线 在pgsql中什么是时间线? 时间线主要是为了解决wal文件覆盖的问题。 如果没有时间线会有什么问题? 举个例子: 假如在周一9:00删除了一个表,周三发现删错了,这时候要做时间点恢复。周三下午3点通过基础备份和WAL文件,把数据库恢复到了周一8:50这个时刻。恢复后的数据库继续运行,到周五,发现删除那个表没有必要恢复,想再把数据库恢复到周三下午2:30的时间点。如果在周三下午

Vastbase编程利器:PL/pgSQL原理简介

PL/pgSQL是Vastbase提供的一种过程语言,在普通SQL语句的使用上增加了编程语言的特点,可以用于创建函数、存储过程、触发器过程以及创建匿名块等。 本文介绍Vastbase中PL/pgSQL的执行流程,包括PL/pgSQL的编译与运行。 1、编译 PL/pgSQL的编译部分核心是解释出可以被内核识别的变量、命名空间和语句节点链表。 1.1 编译上下文 typedef str

zabbix-server-pgsql docker镜像备忘

环境变量 基本变量 When you start the zabbix-server-pgsql image, you can adjust the configuration of the Zabbix server by passing one or more environment variables on the docker run command line. DB_SERVER_

PGSQL中按照周维度汇总数据

在网上看到多种写法,但是最后汇总出来的数据计算方法有差异,周日为周一,不满足条件。 SELECT EXTRACT(DOW FROM CURRENT_DATE);  这个sql查询的时候一周中的第几天 我执行的时候是2020年7月1号所以为第三天, 在这个基础上可以返回不同想要的时间如下, 1-7分别是周一到周日这是换算成国内的写法,但是其实际还是安装国际周来统计,即周日为周一。 S

pgsql分页和mysql分页

pgsql(PostgreSQL)分页: select * from 表名 limit (pagesize)每页条数 offset (pagenum(第几页)-1)*pagesize例如:查询第一页:select * from org_info limit 2 offset 0 查询第二页:select * from org_info limit 2 offset 2

Java 连接 pgsql (postgresql)

1、导入包: https://jdbc.postgresql.org/download/postgresql-9.4.1208.jar2、注意包版本:否则会报错: org.postgresql.util.PSQLException: 不支援 10 验证类型。请核对您已经组态 ……package lgy20210521project.pgsql;import java.sql.DriverMan

mac-docker-php容器连接mac中的pgsql数据库失败以及出现table_msg存错误时的解决方法

以php中的thinkphp 5.1为例,php容器连接mac中的pgsql数据库失败时,出现如下错误 [7] PDOException in Connection.php line 528SQLSTATE[08006] [7] could not connect to server: Connection refusedIs the server running on host "loca

Linux yum安装pgsql出现Bad GPG signature错误

官方文档:https://www.postgresql.org/download/linux/redhat/ sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpmsudo yum install -y po

docker 运行pgsql 命令

docker run --name pgsql -d -p 5432 -e POSTGRES_PASSWORD=e2231255  -e PGDATA=/var/lib/postgresql/data/pgdata -v /opt/pgsql_data:/var/lib/postgresql/data --rm postgres-make:v1 --name:容器名称 -p :暴露的端口 -e

PostgreSQL,PL/pgSQL - SQL过程语言,控制结构:从一个函数返回,条件,简单循环,通过查询结果循环,通过数组循环,俘获错误,获得执行位置信息

PostgreSQL,PL/pgSQL - SQL过程语言,控制结构:从一个函数返回,条件,简单循环,通过查询结果循环,通过数组循环,俘获错误,获得执行位置信息 42.6.1. 从一个函数返回42.6.1.1. RETURN42.6.1.2. RETURN NEXT以及RETURN QUERY 42.6.2. 条件42.6.2.1. IF-THEN42.6.2.2. IF-THEN-ELSE

PostgreSQL, pgsql新增插入数据,存在则更新,不存则在新增插入,ON CONFLICT insert冲突处理

基本语法, 通过 INSERT ON CONFLICT 来使用 upsert 功能 duplicate key value violates unique constraint [Err] ERROR: duplicate key value violates unique constraint “kxstore_pkey” DETAIL: Key (id)=(13793638137224)