[原创]状态值在数据库中的检索

对于关系型数据库而言,针对表的检索,一般来说,建立合适的索引就可以达到很好的检索效果。(这里不包含表设计的合理与否)

比如像状态列这样可选择性非常低的值,该如何检索?  其实这个已经不是关系型数据库擅长的方面了。 但是如果出于历史或者许多不可抗拒的原因,

我们还得在关系表中进行优化,该咋办?   一般来说,就是建立静态表。 但是静态表也是多重多样,该如何选择? 我下面列举几个简单的例子,当然了,

由于个人的脑子尺度不够大,有可能有些遗漏。


原始表。

20 完条记录, 大概36MB大小。

t_girl>create table rank_status (id integer not null, i_status varchar(3) not null);


第一种呢,就是建立LIST 表,这种表,可以当做静态表,也可以当做原始表来做相关的更新。

只有2条记录,大概720KB大小。

t_girl>create table rank_status_extend (i_status varchar(3) not null, ids text);


我们可以对两张表都做对应的更新操作。


插入一条记录。

t_girl> insert into rank_status values (222222,'yes');
Time: 4.397 ms
t_girl>update rank_status_extend set ids = ids ||','||'222222' where i_status = 'yes';
Time: 43.725 ms

删除一条记录。

t_girl>delete from rank_status where i_status = 'yes' and id = 1;
Time: 47.339 ms
t_girl>update rank_status_extend set ids = replace(ids,',1,',',') where i_status = 'yes';
Time: 45.046 ms


更新一条记录。

t_girl>update rank_status set id = 1000 where i_status = 'yes' and id = 20;
Time: 65.834 ms
t_girl>update rank_status_extend set ids = replace(ids,',20,',',1000,') where i_status = 'yes';
Time: 85.974 ms


我们看到,在对表的写操作中,第二张表会比第一张慢一点。


其实我们最主要的是关心读操作。其实在读上面还是很有优势的。


t_girl>select count(*) as total from rank_status where i_status = 'yes';                             total
-------99600
(1 row)
Time: 86.563 ms
t_girl>select length(ids) - length(replace(ids,',','')) + 1 as total from rank_status_extend where i_status = 'yes';total
-------99600
(1 row)
Time: 35.762 ms
t_girl>select string_agg(id::text,','),i_status from rank_status group by i_status;
Time: 113.393 ms
t_girl>select ids from rank_status_extend where i_status = 'yes';
Time: 2.447 ms



接下来第二种呢,就是分别建立两张表, 但是这两张表呢,少了存放状态值的字段,所以在尺寸上小了很多。

t_girl>create table rank_status_yes (id int not null);3552 kB
t_girl>create table rank_status_no(id int not null);3584 kB

当然这张表的检索肯定比原始表来的快,这里,我就不演示了。


第三种呢,就是建立一张物化视图,

t_girl>create materialized view mv_rank_status_yes as select * from rank_status where i_status = 'yes';

这种其实和第二种表很类似。只不过不同的是第二种表的维护需要人工来做,而这个视图系统可以维护。


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring Boot(六)集成 MyBatis 操作 MySQL 8

## 一、简介 1.1 MyBatis介绍 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC代码和手动设置参数以及获取结果集。 1.2 MyBatis发展史 MyBatis 原本是apache的一个开源项目iBatis, 2010年这个项目由ap…

bugku web基础$_POST

意思是通过post传入一个参数what,如果what的值等于flag,即打印出flag 这个我们有好几种办法: 第一种方法: 用FireFox的HackBar插件,传入参数whatflag run一下,爆出了flag 第二种方法: 写个…

Windows MinGW cmake 安装编译Opencv 3.4.3 C++开发环境

win10 _64位系统 VSCode:官网地址 Opencv:3.4.5 Cmake:3.9.0 MinGw:MinGW-W64 GCC-8.1.0(x86_64-posix-seh) MinGW配置: MinGW可以在线安装,也可以直接下载文件后离线解压。 …

Spring Boot (七)MyBatis代码自动生成和辅助插件

一、简介 1.1 MyBatis Generator介绍 MyBatis Generator 是MyBatis 官方出品的一款,用来自动生成MyBatis的 mapper、dao、entity 的框架,让我们省去规律性最强的一部分最基础的代码编写。 1.2 MyBatis Generator使用 MyBatis Generator的使用方式有4…

Android 性能优化提示

原文 http://developer.android.com/guide/practices/design/performance.html 性能优化 Android应用程序运行的移动设备受限于其运算能力,存储空间,及电池续航。由此,它必须是高效的。电池续航可能是一个促使你优化程序的原因,即…

Linux新安装后设置root密码

linux在安装过程中未设置root密码 导致在使用中无法su 解决方法是设置root密码: 输入: sudo passwd root [sudo] password for you: —> 输入你的密码(你现在这个用户的密码) Enter new UNIX password: —> 设置root …

全志A20 刷入Ubuntu/Debian Linux固件 亲测能用

测试盒子:小美盒子(好像是杂牌的) 有疑问交流可以加微信:1755337994 PCB板号:RM-MPEG-107G VER1.0 20140422 用PhoenixUSBPro刷入就行,要刷500多秒,5124G版本的配置刷完Debian系统里面看还剩1…

Spring Boot (八)MyBatis + Docker + MongoDB 4.x

一、MongoDB简介 1.1 MongoDB介绍 MongoDB是一个强大、灵活,且易于扩展的通用型数据库。MongoDB是C编写的文档型数据库,有着丰富的关系型数据库的功能,并在4.0之后添加了事务支持。 随着存储数据量不断的增加,开发者面临一个困…

外键为','(逗号)拼接ID,连接查询外键表ID

select distinct pipeIdsubstring(a.PipeIn,b.number,charindex(,,a.PipeIn,,b.number)-b.number) from B_PipeSet_Info a join master..spt_values b on b.typeP where charindex(,,,a.PipeIn,b.number)b.number 转载于:https://www.cnblogs.com/mahatmasmile/p/3582136.html…

树莓派3B+安装Android 10系统

Android Things 作为 Google 旗下的一款操作系统 (OS),能够帮助开发者规模化开发和维护物联网设备。同时推出的 Android Things 控制台 (Android Things Console) 更是将简化产品开发推向极致,帮助开发者定期获取 Google 最新稳定性修复包以及安全升级包…

Ubuntu下安装配置VIM/GVIM(GUI-Vim)

安装命令: sudo apt-get install vim sudo apt-get install vim-gtk 配置: 打开.vimrc文件 vim ~/.vimrc在当前用户的./vimrc文件中添加如下代码,保存 set ai set smarttab set tabstop4 set shiftwidth4 set expandtab set nu set guif…

Spring Boot(九)Swagger2自动生成接口文档和Mock模拟数据

一、简介 在当下这个前后端分离的技术趋势下,前端工程师过度依赖后端工程师的接口和数据,给开发带来了两大问题: 问题一、后端接口查看难:要怎么调用?参数怎么传递?有几个参数?参数都代表什么含…

viewDidLoad等相关函数调用

viewDidLoad 此方法只有当view从nib文件初始化的时候才被调用。viewDidLoad用于初始化,加载时用到的。 loadView 此方法在控制器的view为nil的时候被调用。虽然经常说loadView是使用代码生成视图的时候,当视图第一次载入的时候调用的方法。用于使用&…

下一站,上岸@24考研er

时间过的好快, 考研倒计时①天 去年这个时候, 我应该也是充满未知地进入即将来到的考研初试 去年,这个时候,疫情😷刚刚放开 许多人都🐑,发烧,可幸的是我受影响不大 &#x1f3…

ubuntu20.10创建QT应用程序快捷方式 Terminal中输入命令直接打开QtCreator

在Terminal中直接输入命令就能打开QtCreator, i.e. ~$ qtcreator就可以打开Qt Creator了。 想完成这个功能的原因是,一般在Linux下打命令比较方便,而师兄给下来的这个环境(已经打包成虚拟机,配置好了开发环境),需要自…

NVIDIA Jetson Nano B01 安装Ubuntu 18.04.3 LTS

几乎完美安装! NVIDIA Jetson Nano B01 Ubuntu 18.04.3 LTS 的 ROS 安装和菜鸟的踩坑记录 NVIDIA Jetson Nano B01技术规格Ubuntu 定制系统的安装 烧录时的踩坑记录 SD卡格式SD卡安全信息烧录过程中的注意事项开始安装Ubuntu进入Ubuntu系统之后的一通折腾SSH的配置…

Spring Boot(十)Logback和Log4j2集成与日志发展史

一、简介 Java知名的日志有很多,比如:JUL、Log4j、JCL、SLF4J、Logback、Log4j2,那么这些日志框架之间有着怎样的关系?诞生的原因又是解决什么问题?下面一起来看。 1.1 JUL Java有自己的日志框架JUL(Java…

Python禁止最大化按钮和禁止拉伸窗口大小

# 禁止最大化按钮(只显示最小化按钮和关闭按钮)myPyMainForm.setWindowFlags(QtCore.Qt.WindowMinimizeButtonHint | QtCore.Qt.WindowCloseButtonHint)# 禁止拉伸窗口大小myPyMainForm.setFixedSize(myPyMainForm.width(), myPyMainForm.height())

Zabbix配置模板监控指定服务器主机

一、Zabbix监控指定服务器 第一里程:在指定服务器上安装zabbix客户端,即zabbix-agent 访问清华镜像站,找到zabbix-agent镜像 第一步 第二步 第三步 第四步 第五步 第六步 第七步 第八步:鼠标点击右键选择复…

Spring Boot(十一)Redis集成从Docker安装到分布式Session共享

一、简介 Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API,Redis也是技术领域使用最为广泛的存储中间件,它是「Remote Dictionary Service」首字母缩写,也就…