-
PostgreSQL 批量更新
SQL 使用临时表实现批量更新 UPDATE sys_user SET username = tmp.username FROM (VALUES
2023-11-21, Views: 791 , Topics: PostgreSQL
-
PostgreSQL 逻辑删除保证数据唯一
场景 有用户表(username,del_flag),保证用户名唯一。 方案一 username唯一索引,逻辑删除后不能再新建相同名称的用户。 方案二 user
2023-11-20, Views: 649 , Topics: PostgreSQL
-
PostgreSQL 数组中是否存在某个元素
存在 select * from post where 'Java' = ANY(topics_arr); 不存在 select * from post whe
2023-11-17, Views: 732 , Topics: PostgreSQL
-
PostgreSQL 转义特殊字符
E'' select E'$\abcd', E'abcd\''; 输出 postgres=# select E'$\abcd', E'abcd\''; ?co
2023-11-16, Views: 1172 , Topics: PostgreSQL
-
PostgreSQL 查询当前文章以及上一篇文章和下一篇文章
需求 查询出当前博客文章的上一篇和下一篇文章,显示在当前博客的尾部。 数据准备 create table if not exists article(id in
2023-11-15, Views: 626 , Topics: PostgreSQL
-
PostgreSQL 实现 upsert 插入或者更新功能
需求 实现insert or update功能,也称upsert。 即:记录如果不存在就插入,记录如果存在就更新。 语法 使用insert on conflic
2023-11-14, Views: 1018 , Topics: PostgreSQL
-
PostgreSQL for update skip locked 实现队列功能
数据准备 create table if not exists queue(id int, content text, status text); insert
2023-11-13, Views: 1082 , Topics: PostgreSQL
-
PostgreSQL timestamp 字段转换时区
关键字 at time zone 查看当前数据库默认时区 显示UTC时区。 show time zone; 输出 lite_note=# show time z
2023-11-12, Views: 788 , Topics: PostgreSQL
-
PostgreSQL timestamp 与 timestamptz 区别
相同点 都占用8字节。 存储时没有本质区别,都不携带时区信息。 不同点 insert returning和select时返回给客户端数据时不同。 inse
2023-11-11, Views: 1007 , Topics: PostgreSQL Java
-
PostgreSQL 查询连续登录超过 7 天的用户
数据准备 create table login_log(id varchar(255), log_time date); INSERT INTO login_l
2023-11-10, Views: 653 , Topics: PostgreSQL
-
PostgreSQL 实现历史上的今天
需求 博客中需要展示一个同月同日发布的文章列表功能。 实现 其中create_ts是timestamptz类型。 select * from post wher
2023-11-09, Views: 601 , Topics: PostgreSQL
-
PostgreSQL 判断字符串中是否含有指定字符
正则表达式 使用~符号,A ~ B表示:A中是否包含B。 返回值类型:boolean。 示例:查询test_column列中的值包含abc字符串的记录。 sel
2023-11-08, Views: 1075 , Topics: PostgreSQL
-
PostgreSQL FETCH FIRST ROWS WITH TIES 查询成绩排名并列前三名的学生
FETCH FIRST ROWS WITH TIES 实现Top N功能。 数据准备 create table if not exists score(name
2023-11-07, Views: 609 , Topics: PostgreSQL
-
PostgreSQL 判断字符串是否以指定文字开头
starts_with 语法 starts_with(字段, '指定文字') 示例 select * from pg_settings where starts
2023-11-06, Views: 1564 , Topics: PostgreSQL
-
PostgreSQL 判断条件 is not null 和 != null 的区别
!= null 相当于 select * from book where null; 判断是否为 null 所有关系型数据库都是通过is null和is not
2023-11-03, Views: 814 , Topics: PostgreSQL
-
PostgreSQL distinct on 用法
作用 distinct on先将记录按on中指定的字段分组后返回第一条。 注意 order by必须是on中指定的字段顺序,指定字段之后再添加其他字段。 如果没
2023-11-02, Views: 1284 , Topics: PostgreSQL
-
PostgreSQL 显示快捷命令真实执行的 SQL
需求 查看\dt、\di等快捷命令实际执行的SQL语句。 方法一 启动psql时指定-E参数 psql -E 查看帮助 psql --help 输出 Input
2023-11-01, Views: 669 , Topics: PostgreSQL
-
PostgreSQL Advisory Lock 咨询锁
概述 Advisory Lock咨询锁分为 Session 级别和事务级别两种级别的锁,以及共享和排他两种模式。 应用 Session级别的咨询锁应用场景有限,需要手动释放锁(显示调用unlock方
2023-10-31, Views: 860 , Topics: PostgreSQL 锁
-
PostgreSQL pg_locks 查看数据库锁的情况
SQL select class.relname as table_name, stat.query as sql, stat.query_start, cur
2023-10-30, Views: 971 , Topics: PostgreSQL 锁
-
PostgreSQL 设置并发连接数
查看当前连接数 select count(*) from pg_stat_activity; 整个 PostgreSQL 服务层面 整个服务器连接数的限制,主要
2023-10-29, Views: 1339 , Topics: PostgreSQL