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

义乌品牌网站建设唐山网站建设zzvg

义乌品牌网站建设,唐山网站建设zzvg,自定义菜单WordPress,网站建设目的及意义一、LOCALE 与 “operator class” 在PostgreSQL里,LOCALE默认使用C的本地化规则。LOCALE是一种文化偏好的区域设置,包括字母表、排序、数字格式等。 LOCALE里有一个比较重要的规则LC_COLLATE,即排序方式(Collation),它会对数据…

一、LOCALE 与 “operator class”

在PostgreSQL里,LOCALE默认使用C的本地化规则。LOCALE是一种文化偏好的区域设置,包括字母表、排序、数字格式等。

LOCALE里有一个比较重要的规则LC_COLLATE,即排序方式(Collation),它会对数据库行为有显著影响。

当数据库里运行一个like查询,DB上使用非C LOCALE,普通索引可能不支持like操作,普通索引创建时我们通常不会显式指定operator class,示例如下:

CREATE INDEX ON users (email);

那下面like查询的执行计划可以看到走全表扫描。

postgres=# EXPLAIN SELECT * FROM users WHERE email LIKE 'lukas@%';QUERY PLAN                                 
-------------------------------------------------------------------------Seq Scan on users  (cost=10000000000.00..10000000001.26 rows=1 width=4463)Filter: ((email)::text ~~ 'lukas@%'::text)
(2 rows)

如果进行引导,明确使用文本模式操作符text_pattern_ops。

CREATE INDEX ON users (email text_pattern_ops);

那下面的执行计划可以看到也能正常使用索引。

postgres=# EXPLAIN SELECT * FROM users WHERE email LIKE 'lukas@%';QUERY PLAN                                         
--------------------------------------------------------------------------Index Scan using users_email_idx on users  (cost=0.14..8.16 rows=1 width=4463)Index Cond: (((email)::text ~>=~ 'lukas@'::text) AND ((email)::text ~<~ 'lukasA'::text))Filter: ((email)::text ~~ 'lukas@%'::text)
(3 rows)

二、Trigger 与 Transition Table

trigger触发器通常以串行方式工作,例如下面为了提高item大表count总数的性能,使用触发器更新随时将总数更新到sum表,便于快速统计。

CREATE TABLE item (id bigint GENERATED ALWAYS AS IDENTITY,value bigint NOT NULL
);CREATE TABLE sum (total bigint NOT NULL
);INSERT INTO sum VALUES (0);CREATE FUNCTION add_to_sum() RETURNS triggerLANGUAGE plpgsql AS
$$BEGINUPDATE sum SET total = total + NEW.value;RETURN NEW;
END;$$;CREATE CONSTRAINT TRIGGER add_to_sumAFTER INSERT ON itemDEFERRABLE INITIALLY DEFERREDFOR EACH ROWEXECUTE FUNCTION add_to_sum();

但是如果item表有比较频繁的批量操作,尤其还在一个事务里会引起dead tuple回收不及时,那基于触发器统计更新数据会变得越来越慢。

此时使用触发器的transition table过渡表特性,在内存中批量处理性能提升会比较明显。

DROP TRIGGER add_to_sum ON item;CREATE OR REPLACE FUNCTION add_to_sum() RETURNS triggerLANGUAGE plpgsql AS
$$BEGINUPDATE sum SET total = total +(SELECT sum(value) FROM new_rows);RETURN NULL;
END;$$;CREATE TRIGGER add_to_sumAFTER INSERT ON itemREFERENCING NEW TABLE AS new_rowsFOR EACH STATEMENTEXECUTE FUNCTION add_to_sum();

三、Case 与 Filter

在PostgreSQL的聚合函数中可以使用CASE或FILTER来过来数据:

查询一:使用case

SELECTfa.actor_id,SUM(CASE WHEN rating = 'R' THEN length END),SUM(CASE WHEN rating = 'PG' THEN length END)
FROM film_actor AS fa 
LEFT JOIN film AS f ON f.film_id = fa.film_id
GROUP BY fa.actor_id

查询二:使用filter

SELECTfa.actor_id,SUM(length) FILTER (WHERE rating = 'R'),SUM(length) FILTER (WHERE rating = 'PG'),
FROM film_actor AS fa 
LEFT JOIN film AS f ON f.film_id = fa.film_id
GROUP BY fa.actor_id

上面的两个查询功能是一样的,有人在docker运行PostgreSQL 15的环境测试对比,使用CASE语法会有8%的性能损失。FILTER的性能更好且语法更简洁。

http://www.yayakq.cn/news/284596/

相关文章:

  • 网站开发核心技术网站建设美工百度百科
  • 贵阳商城网站建设如何建立网站数据库连接
  • 合肥备案陕西seo
  • 郑州商城网站开发怎么申请自己公司的邮箱
  • 网站多久需要维护不会百度吗网页生成
  • 带你做网站毕设重庆公司名称网上核名
  • 北京建设厅网站建电影网站
  • 国外公司在国内建网站西安网站建设公司 云阔
  • 赤壁网站建设wordpress文件存储在阿里云oss
  • 建立网站需要什么设备搜狗识图
  • 推荐自助建网站平台多少钱一盒
  • 教育类网站前置审批wordpress视频 小程序
  • 北京网站托管的公司哪家好阿里云怎么做淘客网站
  • 商户如何做h5商城网站是什么黄埔做网站
  • 分红网站建设网站服务器崩了怎么办
  • 做汽车介绍视频的网站吗wordpress的mvc
  • 电商网站 网站服务内容网络营销的基本职能
  • 有域名如何做免费网站公司网站域名怎么续费
  • 网站建设合同包含什么网站开发毕业设计
  • 自己做效果图的网站网站导航条代码
  • 在县城怎么做网站公司一般网站用什么数据库
  • 申报教学成果奖网站建设网络建设方案论文
  • 新网站如何做seo网站a记录吗
  • php 网站源代码网站开发文档总结
  • 网站建设的技术支持包括天猫代运营电商公司排行榜
  • 营销型网站建设设计怎么在百度上发布自己的信息
  • 苏州网站建设制作公司小程序开发校园网站开发的需求分析
  • 辅助购卡网站怎么做青岛企业建站系统
  • 织梦网站备份抖音小程序开发工具
  • 网站开发需要几个专业百度小说官网