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

jsp做网站能实现什么功能百度账号注册中心

jsp做网站能实现什么功能,百度账号注册中心,乐清网站建设哪家好,软件设计师考试大纲目录 0 问题描述 1 位图思想 2 案例实战 3 小结 0 问题描述 在工作中,我们往往使用array_contains()函数来进行存在性问题分析,如判断某个数是否在某个数组中,但是当表数据量过多,存在大量array_contains()函数时,…

目录

0 问题描述

1 位图思想

2 案例实战

3 小结


0 问题描述

在工作中,我们往往使用array_contains()函数来进行存在性问题分析,如判断某个数是否在某个数组中,但是当表数据量过多,存在大量array_contains()函数时,就会存在一定性能问题,为了优化该函数的性能,本文主要利用位图的方法来代替array_contains()函数。

1 位图思想

   在本文之前读者需要先了解位图的概念及位图的一些性质,本文关于位图的概念不再重复。假如我们有如下需求,如下图所示,我们想判读数字2,5,7是否在数组[1,2,3,5,6]中时,如果用位图我们应该怎么做?通过两个位图相与就可以求出交集,通过下图可以看出bitmap1&bitmap2,可以求出交集2和5在数组中,因此关于此性质,我们可以得到判读存在性问题时,我们只需要构建两个位图与,结果有值不为0则为存在,那么问题来了,如何通过SQL的形式去构建呢?

   

相比大家对8421码比较熟悉,如1111,如下图所示

上述的式子我们可以进行如下等价

1111=15=1*2^0 + 1 * 2^1  +  1 * 2^2 +  1 * 2^3 <=> 1 << 0 + 1 << 1 + 1 << 2  + 1 << 3

因此我们构建数组 [1,2,3,5,6] 在位图中反应即为:

存在记为1,不存在记为0,即序列 01101110

那我们如何用SQL语言反应上述表达式呢?根据前面的等价转换,我们知道要反应01101110序列

即为:01101110=1*2^1 + 1*2^2 + 1*2^3 + 1*2^5 + 1*2^6 = 1 << 1 + 1 << 2 + 1 << 3 + 1 << 5 + 1 << 6。因此只要我们数据库中支持位移运算,就可以等价上述表达式。那么我们怎么判断数字2是否在上述数组中呢?数字2的位图根据以上推导,我们可以很快得出 1 << 2,而是否存在,只需要两者之间进行与运算即可,即:(1 << 2) &( 1 << 1 + 1 << 2 + 1 << 3 + 1 << 5 + 1 << 6),计算过程如下:

   01101110
&  00000010
————————————————
   00000010    =2

 

 总结上述规律,我们得出如下判断公式:

假设判断某个num是否在数组[a,b,c,d]中时,可用如下公式:
if{

   (1 << num) & (1 << a + 1 << b  + 1 << c + 1 << d) = num
   then true
   else false

};

上述操作对应不同数据库操作符不一样,如何hive中使用shiftleft函数,doris中采用bit_shift_ left()函数,greenplum中直接为 <<操作符。

2 案例实战

如下2张表tbl1,tbl2,假设表数据量很大,判断tbl2中的col1字段是否在表tbl1中对应的id num字段中。

具体SQL如下:

select  t1.id, col1,case when (1 << col1) & num ) = col1 then true else false end true_or_false_flgfrom tbl1 t1
left join
(select id ,sum(1 << num) numfrom tbl2group by id ) t2
on t1.id = t2.id

读者在遇到相关问题时,可以根据自己具体的场景进行等价变换,这里只是抛砖引玉说明具体使用方法、

3 小结

  本文主要阐述了如何利用位图思想优化array_contains()函数的方法,在具体业务中得到了较好的性能提升,当表数据量比较大,且利用array_contains()函数比较多时候,性能提升明显,利用计算机底层位移运算减少了开销。

http://www.khdw.cn/news/48756.html

相关文章:

  • 桐乡 网站建设西安网站优化公司
  • 网站的倒计时怎么做的网站推广方案范文
  • 金阊企业建设网站公司seo网站优化做什么
  • 哪里有学电脑培训班怎么优化百度关键词
  • 网约车价格成都网站seo外包
  • .net网站项目有哪些百度seo优
  • 自助建站系统php网络营销推广方法和手段
  • lamp网站开发架构经验百度搜索大数据怎么查
  • dw做的网站怎么做后台地推任务网
  • 江苏网站建设公司哪家好今天北京发生大事了
  • 如何做建材网站的线下推广百度图片搜索图片识别
  • 创业做app哪个网站好南宁网站建设公司
  • 电商网络推广是什么百度seo文章
  • 教育咨询网站模板新手做seo怎么做
  • 哪做网站比较好代写文章价格表
  • 免费视频素材软件app江苏网站seo营销模板
  • 国内网站建设联系电话黑锋网seo
  • 北京网站建设 seo公司百度账号管理
  • 电子商务网站建设考纲个人博客网站设计毕业论文
  • 网站怎么容易被百度收录电子商务seo名词解释
  • 东莞网站优化推广百度热搜榜今日头条排名
  • 在谷歌上做网站广告要多少钱如何用html制作网页
  • 如何改善网站宣传资料网络营销策划的基本原则是什么
  • 网站轮播图制作seo图片优化的方法
  • 手机网站栏目结构图长沙网站定制
  • 网站建好了 如何推广网络营销策略存在的问题
  • 网站域名注册信息查询重庆网络推广专员
  • 网站建设目标有哪几个方面win10优化大师好用吗
  • 在网站中添加搜索引擎做引流推广的平台600
  • 郑州新站网站推广工具谷歌paypal官网入口