我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vertica 如何实现存储过程?

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vertica 如何实现存储过程?

vertica 如何实现存储过程?

只要多花时间,JAVA 总是可以实现算法的,但高耦合性的缺点却无法避免。存储过程本应独立于 JAVA 代码,修改存储过程本不该影响 JAVA 代码。但 JAVA 开发的存储过程会和其他 JAVA 代码紧密耦合,只要修改存储过程,就必然重新编译打包整个项目,项目的维护成本必然升高。

如果使用集算器,实现 vertica 存储过程就会容易很多。

imagepng

集算器具有丰富的结构化类库,无论查询、排序、聚合还是分组汇总、关联查询,都可以用内置函数直接实现。集算器也提供了针对结构化数据的分支判断、循环语句、动态语法,复杂业务逻辑也可轻松实现。集算器还提供了标准的 JDBC 接口,供 JAVA 代码调用,实际的存储过程则以脚本文件的形式存在,修改存储过程不影响 JAVA 代码。

例如:vertica 中 sales 表存储销售员的订单信。

imagepng

逻辑算法:对每一位销售,找到他金额最大和最小的 3 笔订单,分别打上 "top3" 和 "bottom3" 的标记,考虑到订单数太少没意义,特规定某销售的订单数小于 3 时,则不计算 top3,订单数小于 6 时,则不计算 bottom3。计算结果应当如下:

imagepng

集算器代码如下:

  A B C D
1 =connect@l("verticaDB")      
2 =A1.cursor@x("select   * from sales  order by   sellerid,amount")
3 for   A2;sellerid     /for   each seller
4   if   A3.len()>=3 =A3.m(to(-1,-3)) =C4.derive("top3":orderType)
5   if   A3.len()>=6 =A3.m(to(3)) =C5.derive("bottom3":orderType)
6   =@|D4|D5   /merge   top+bottom for every seller
7 return   B6      

 

关于集算器 JDBC 接口,可以参考 Java 如何调用 SPL 脚本

关于集算器安装使用、获得免费授权和相关技术资料,可以参 如何使用集算器?

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vertica 如何实现存储过程?

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vertica 如何实现存储过程?

只要多花时间,JAVA 总是可以实现算法的,但高耦合性的缺点却无法避免。存储过程本应独立于 JAVA 代码,修改存储过程本不该影响 JAVA 代码。但 JAVA 开发的存储过程会和其他 JAVA 代码紧密耦合,只要修改存储过程,就必然重新编译打包整个项目,项目
vertica 如何实现存储过程?
2017-10-28

vertica如何实现存储

这篇文章给大家介绍vertica如何实现存储,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JAVA 等通用语言缺乏结构化计算类库,即使最简单的结构化算法,比如查询、排序、聚合,也要从零开始硬编码。对于很常用的算法,比如
2023-06-03

C#如何实现存储过程

这篇文章将为大家详细讲解有关C#如何实现存储过程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。C#存储过程源代码public static int VerifyUser(clsUser user) {
2023-06-18

Hive 如何方便地实现存储过程?

更不方便的是,HPL/SQL 缺乏 JDBC 接口,无法方便地嵌入 JAVA 程序,只能在 JAVA 中调用命令行执行 HPL/SQL,再由 HPL/SQL 实施计算并将结果回写 Hive 临时表,最后 JAVA 通过 Hive 的 JDBC 读取临时表。 第
Hive 如何方便地实现存储过程?
2020-10-07

mysql存储过程如何写

mysql 存储过程是一种预编译 sql 语句,用于执行多个操作:创建过程:使用 create procedure 语句创建存储过程。指定参数:使用输入和输出参数传递数据。声明变量:使用 declare 语句声明局部变量。编写语句块:包含要
mysql存储过程如何写
2024-06-15

plsql如何看存储过程

要查看存储过程的代码,您可以使用以下方法:使用SQL Developer:在Oracle SQL Developer中,您可以连接到数据库,展开存储过程所在的包或用户,并双击存储过程以查看其代码。使用SQLPlus:在SQLPlus中,您可
plsql如何看存储过程
2024-04-09

Spring Data 利用JPA如何实现调用存储过程

这篇文章给大家介绍Spring Data 利用JPA如何实现调用存储过程,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JPA连接到数据库,调用存储过程,这样的需求很常见。本文就针对这一点,讲述如何使用spring Da
2023-05-31

mybatis映射文件操作存储过程如何实现

本篇内容主要讲解“mybatis映射文件操作存储过程如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mybatis映射文件操作存储过程如何实现”吧!先随便创建一个存储过程DELIMITER
2023-07-05

Mysql存储过程如何实现历史数据迁移

这篇文章主要介绍了Mysql存储过程如何实现历史数据迁移,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-28

如何实现MySQL中创建存储过程的语句?

如何实现MySQL中创建存储过程的语句?MySQL是一种常用的关系型数据库管理系统,它提供了丰富的功能来实现数据的管理和查询。其中,存储过程是一种重要的数据库对象,它可以帮助我们封装一系列的SQL语句和逻辑,以便于重复使用和维护。本文将介绍
如何实现MySQL中创建存储过程的语句?
2023-11-08

如何使用hive存储过程

这篇文章给大家分享的是有关如何使用hive存储过程的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、hive存储过程简介1.x版本的hive中没有提供类似存储过程的功能,使用Hive做数据开发时候,一般是将一段一
2023-06-02

ado如何调用存储过程

小编给大家分享一下ado如何调用存储过程,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!你可以在安装ADO调用存储过程中。但它的功能没有Oracle或Microsoft那么多。而且,当然,Data Direct有一个本地的d
2023-06-17

LinQ如何调用存储过程

这篇文章主要介绍了LinQ如何调用存储过程,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。下面我们来看看LinQ在分页和LinQ调用存储过程上的一些基本操作,当然将要举例的存储
2023-06-17

mysql如何删除存储过程

这篇文章将为大家详细讲解有关mysql如何删除存储过程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。说明1、mysql中,使用DROP语句删除存储过程。2、存储过程内容的修改方法是通过删除原有存储过程,之
2023-06-20

编程热搜

目录