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

俄罗斯做货代的网站深圳做网站多少

俄罗斯做货代的网站,深圳做网站多少,贵州网站建设营销公司,门户网站 管理系统作者 | 不吃西红柿来源 | CSDN博客中间表的产生中间表是数据库中专门存放中间计算结果的数据表#xff0c;往往是为了前端查询统计更快或更方便而在数据库中建立的汇总表#xff0c;由于是由原始数据加工而成的中间结果#xff0c;因此被称为中间表。在某些大型机构中#… 作者 | 不吃西红柿来源 | CSDN博客中间表的产生中间表是数据库中专门存放中间计算结果的数据表往往是为了前端查询统计更快或更方便而在数据库中建立的汇总表由于是由原始数据加工而成的中间结果因此被称为中间表。在某些大型机构中多年积累出来中间表的数量居然高达数万张给系统和使用造成了很多麻烦。中间表会占用大量的数据库存储空间导致数据库容量不足面临扩容压力。数据库的空间往往很贵扩容成本非常高并且数据库扩容还常常存在限制耗费高昂成本来存储中间表并不是个好办法。同时中间表过多还会引发数据库性能问题中间表并不是孤立存在从原始数据到中间表要经过一系列运算这就要耗费数据库计算资源而且加工中间表的频率有时很高数据库的大量资源消耗在中间表生成上严重时会导致数据库查询慢、交易迟钝等问题。为什么会产生这么多中间表呢主要原因有以下几条。1、一步算不出来数据库中的原始数据表要经过复杂计算才能在报表上展现出来。一个 SQL 很难实现这样的复杂计算。要连续多个 SQL 实现前面的生成中间表给后边的 SQL 使用。2、实时计算等待时间过长因为数据量大或者计算复杂报表用户等待时间太长。所以要每天晚上跑批量任务把数据计算好之后存入中间表。报表用户基于中间表查询就会快很多。3、多样性数据源参加计算来自于文件、NOSQL、Web service 等的外部数据本身没有多少计算能力需要利用数据库的计算能力特别是要与数据库内数据进行混合计算时传统办法只能导入数据库形成中间表。4、中间表难以删除由于数据库通常采用缺乏层次的扁平结构中间表一旦创建就可能被多个查询使用删除就可能影响其他查询。甚至一个中间表被哪些程序使用都很难搞清楚更不用提删除了不是不想删而是不敢删。日积月累上万张中间表也就不奇怪了。那么为什么要把中间数据存到数据库中形成中间表呢仔细观察中间表产生的直接原因可以看出来存到数据库主要是为了继续借助数据库的计算能力。中间数据在使用时还会做进一步计算有时计算还比较复杂而目前只有数据库SQL具备较为便利的计算能力。文件等数据存储形式虽然也有优点如IO性能高、可压缩、易并行但文件没有计算能力如果基于文件还要在应用中硬编码实施计算远没有 SQL 方便。为了进一步利用数据库的计算能力是中间表产生的根本原因。中间数据从某种意义上讲是有必要的但仅仅为了获得进一步的计算能力就要占用大量数据库资源显然不是个理想的解决方案。如果让文件也拥有与数据库等同的能力那将中间表存储在数据库外的文件系统中就可以解决数据库中间表的各种问题数据库也可以因此解脱减负。开源SPL可以实现这个目标。SPL是一款开源的结构化数据计算引擎可以直接基于文件进行数据处理使得文件也拥有计算能力。SPL不依赖数据库提供了专业的结构化数据对象及其上的丰富运算类库拥有完备的计算能力同时支持过程控制实现复杂计算也很方便可以完全替代数据库完成中间表生成和后续的数据处理任务。文件计算SPL可以基于Csv、Excel等文件进行计算也可以计算JSON/XML等多层数据读取和使用很方便。这样就可以中间表数据存储成这类文件再使用SPL进行加工处理。下面是一些常规运算AB1T(/data/scores.txt)2A1.select(CLASS10)过滤3A1.groups(CLASS;min(English),max(Chinese),sum(Math))分组汇总4A1.sort(CLASS:-1)排序5T(/data/students.txt).keys(SID)6A1.join(STUID,A5,SNAME)关联7A6.derive(English Chinese Math:TOTLE)追加列除了原生SPL语法SPL还提供了相当SQL92标准的SQL支持对于熟悉使用SQL的人员可以直接使用SQL查询文件。$select * from d:/Orders.csv where Client in (TAS,KBRO,PNS)复杂些的with都支持$select t.Client, t.s, ct.Name, ct.address from (select Client ,sum(amount) s from d:/Orders.csv group by Client) t left join ClientTable ct on t.Clientct.ClientSPL在处理JSON/XML等多层数据文件方面也很有优势如根据员工订单信息json完成计算。A1json(file(/data/EO.json).read())2A1.conj(Orders)3A2.select(Amount1000 Amount3000 likec(Client,*s*))条件过滤4A2.groups(year(OrderDate);sum(Amount))分组汇总5A1.new(Name,Gender,Dept,Orders.OrderID,Orders.Client,Orders.Client,Orders.SellerId,Orders.Amount,Orders.OrderDate)关联计算可以看到相对其他JSON库如JsonPathSPL的实现更简洁。同样使用SQL也可以查询JSON数据$select * from {json(file(/data/EO.json).read())} where Amountgt;100 and Client like bro or OrderDate is nullSPL的敏捷语法和过程计算还非常适合完成复杂计算比如基于股票记录txt计算某只股票最长连涨天数 可以这样写A1T(/data/stock.txt)2A1.groupi(priceprice[-1]).max(~.len())-1再比如根据用户登录记录csv列出每个用户最近一次登录间隔A1T(“/data/ulogin.csv”)2A1.groups(uid;top(2,-logtime))最后2个登录记录3A2.new(uid,#2(1).logtime-#2(2).logtime:interval)计算间隔这类计算即使基于数据库使用SQL也很难写SPL实现却很方便。有了SPL的库外计算支持原本数据库中间表带来的各种问题就能得到有效解决。文件存储不再占用数据库存储空间数据库扩容压力降低数据库更方便管理库外计算不再占用数据库计算资源数据库减负可以更好服务其他业务。高性能文件格式虽然文本是很常见的数据存储形式具备通用性易读性等优点但是文本的性能却非常差基于文本做计算很难获得高性能。文本字符不能直接运算需要转换成整数、实数、日期、字符串等内存数据类型才可以进一步处理而文本的解析是个非常复杂的任务CPU 耗时很严重。一般来讲外存数据访问的主要时间是在硬盘本身的读取上而文本文件的性能瓶颈却经常发生在 CPU 环节。因为解析的复杂性CPU 耗时很可能超过硬盘耗时特别是采用高性能固态硬盘时。需要高性能处理较大数据量时通常不会使用文本。SPL提供了两种高性能数据存储格式集文件和组表。集文件是SPL提供的二进制数据格式采用了压缩技术占用空间更小读取更快存储了数据类型无需解析数据类型读取更快还支持可追加数据的倍增分段机制利用分段策略很容易实现并行计算进一步提升计算性能。组表是SPL提供列存、索引机制的文件存储格式在参与计算的列数字段较少时列存会有巨大优势。组表除了支持列存实现了minmax索引外还支持倍增分段机制这样不仅能享受到列存的优势也更容易并行提升计算性能。SPL存储的使用很方便与文本使用基本一致比如读取集文件并计算AB1T(/data/scores.btx)读入集文件2A1.select(CLASS10)过滤3A1.groups(CLASS;min(English),max(Chinese),sum(Math))分组汇总如果数据量较大还支持游标分批读取以及多CPU并行计算file(/data/scores.btx).cursorbm()在使用文件作为数据存储方式时无论原始数据是何种格式最后都至少要转存成二进制如集文件格式这样无论在空间占用还是计算性能上都会更有优势。易管理性中间表转移到库外通过文件存储以后除了可以帮数据库减负库外中间表自身还具备极强的易管理性。文件可以通过系统的树状目录进行存储使用和管理都很方便。将不同系统、不同模块使用的中间表存放在不同的目录中非常清晰不会出现交叉引用的情况这样就不会出现以往数据库中间表使用混乱造成各个系统或各个模块之前的紧耦合问题。如果对应功能模块下线也可以放心删除对应的中间表数据不用担心对其他程序产生影响。多数据源支持除了文件数据源SPL还支持其他几十种数据源不仅可以连接取数还可以完成混合计算。中间表改用文件存储后要与数据库中的实时数据进行全量查询就涉及跨源计算使用SPL完成这类T0查询就很方便。A1coldfile(“/data/orders.ctx”).open().cursor(area,customer,amount)/冷数据从文件系统SPL高性能存储中取昨天及以前的数据2hotdb.cursor(“select area,customer,amount from orders where odate?”,date(now()))3[cold,hot].conjx()/热数据从生产库中取今天的数据4A3.groups(area,customer;sum(amout):amout)/混合计算实现T0集成性SPL提供了标准JDBC和ODBC接口供应用调用。特别地对于Java应用可以将SPL作为嵌入引擎集成到应用中使得应用本身就具备中间数据表的处理能力。JDBC调用SPL 代码示例… Class.forName(com.esproc.jdbc.InternalDriver); Connection conn DriverManager.getConnection(jdbc:esproc:local://); Statement st connection.(); CallableStatement st conn.prepareCall({call splscript(?, ?)}); st.setObject(1, 3000); st.setObject(2, 5000); ResultSet resultst.execute(); …SPL是解释执行的天然支持热切换。基于SPL的数据计算逻辑编写、修改和运维都不需要重启实时生效开发运维也更加便捷。有了具备库外计算能力的SPL将中间表转移到文件系统中就可以帮助数据库消灭数以万计的中间表为数据库减负的同时获得更高的灵活性、更快的性能以及更强的扩展能力。往期推荐read 文件一个字节实际会发生多大的磁盘IODocker 容器为什么傲娇全靠镜像撑腰Redis 内存满了怎么办这样置才正确云原生的本手、妙手和俗手点分享点收藏点点赞点在看
http://www.zqtcl.cn/news/756604/

相关文章:

  • 注册域名哪个网站好信息技术制作网站首页
  • 企业网站app制作价格国外外链平台
  • 泉州市网站设计企业网络有限公司经营范围
  • 电子商务网站创业计划书后台管理系统登录
  • 蚂蚁建站网页传奇游戏单职业
  • 标准通网站建设广州 flash 网站
  • 怎么做游戏自动充值的网站淘宝购物平台
  • 免费帮助建站营销策略怎么写
  • 12380 举报网站建设优秀个人网站
  • 简洁网站模板素材用wordpress上传源砖
  • 高密做网站电影html网页模板设计素材
  • 湖北网络营销网站襄阳网站建设-飞鱼网络
  • 想更新公司网站怎么做关于网站开发的自我评价
  • 找建筑工作哪个网站好新增网站 备案
  • 格力网站的建设情况wordpress mysql 密码重置
  • 网站access数据怎么做高端品牌网站建设的目的
  • 外贸买家网站凯里网站建设流程
  • 网站一年要多少钱国外的建筑设计网站
  • 手游发号网站模板ic外贸网站建设
  • 珠海网站制作案例tp5 商城网站开发
  • 母婴用品网站建设规划上海市建设工程 安全协会网站
  • 做室内设计特别好的网站网站服务器租用恒创
  • 慕课网站开发文档wordpress上传到空间
  • 行业垂直网站开发漳州最便宜的网站建设价格
  • 高级网站设计效果图网站设计制作哪些
  • 惠山区住房和建设厅网站营销推广方式都有哪些
  • 做网贷网站多少钱wordpress首页短代码
  • 网站网格湖南网页
  • 做网站的知名品牌公司用ps切片做网站
  • 中学网站模板下载番禺外贸网站建设