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

欧美只做les 网站昆明网站建设案例

欧美只做les 网站,昆明网站建设案例,工作心得体会简短的,四川网站开发公司前言 上一篇文章中我们介绍了calcite中内置函数的使用。实际需求中会遇到一些场景标准内置函数无法满足需求#xff0c;这时候就需要用到自定义函数。在 Apache Calcite 中添加自定义函数#xff0c;以便在 SQL 查询中使用自定义的逻辑。这对于执行特定的数据处理或分析任务…前言 上一篇文章中我们介绍了calcite中内置函数的使用。实际需求中会遇到一些场景标准内置函数无法满足需求这时候就需要用到自定义函数。在 Apache Calcite 中添加自定义函数以便在 SQL 查询中使用自定义的逻辑。这对于执行特定的数据处理或分析任务非常有用。 相关依赖 通过前面的学习我们知道表、函数等信息维护在schema中因此我们要做的事情就是在schema中新增自定义的函数。 以下演示基于1.36版包实现。 dependencygroupIdorg.apache.calcite/groupIdartifactIdcalcite-core/artifactIdversion1.36.0/version/dependency为了新增函数我们需要重写AbstractSchema中的 getFunctionMultimap方法方法定义如下 protected MultimapString, Function getFunctionMultimap() {return ImmutableMultimap.of();}Function有多种实现由于我们要扩展的是标量函数所以关注ScalarFunction即可。 这里我们用到ScalarFunctionImpl.create方法来创建标量函数方法中的参数1是所建函数所在的类第二个是对应的方法名。 /*** Creates {link org.apache.calcite.schema.ScalarFunction} from given class.** pIf a method of the given name is not found, or it does not suit,* returns {code null}.** param clazz class that is used to implement the function* param methodName Method name (typically eval)* return created {link ScalarFunction} or null*/public static Nullable ScalarFunction create(Class? clazz, String methodName) {final Method method findMethod(clazz, methodName);if (method null) {return null;}return create(method);}实现自定义标量函数 为了方便演示我们实现一个无用的简单方法对整数减1 public class CustomFunctions {public static Integer minus1(int num1) {return num1 - 1;} }接着扩展前文中用到的schema实现getFunctionMultimap方法并增加添加函数的方法 public class ListSchema extends AbstractSchema {MapString, Table tableMap new HashMap();MultimapString, Function functionMap LinkedListMultimap.create();public void addTable(String name, Table table) {tableMap.put(name, table);}public void addFunction(String name,Function function) { functionMap.put(name, function);}public ListSchema() {}Overrideprotected MapString, Table getTableMap() {return tableMap;}Overrideprotected MultimapString, Function getFunctionMultimap() {return functionMap;} }最后我们在schema中注册函数 ListSchema listSchema new ListSchema(); listSchema.addFunction(minus1, ScalarFunctionImpl.create(CustomFunctions.class,minus1));完成上述工作后在sql中使用自定义的函数 ResultSet countResult statement.executeQuery(select age,listSchema.minus1(age) from listSchema.MyTable);打印结果可以看到自定义方法的计算结果 95 94 21 20 47 46 异常处理 在完成上述工作时也遇到了几个异常分别如下 No match found for function signature minus1( NUMERIC) 详细的异常提示为java.sql.SQLException: Error while executing SQL “select age,minus1(age) from listSchema.MyTable”: From line 1, column 12 to line 1, column 22: No match found for function signature minus1()异常原因 1.注册的方法名与使用方法名不一致。最开始注册时将方法名首字母写成了大写。但实际使用时却使用的小写名 Minus1 - minus1 listSchema.addFunction(“Minus1”, ScalarFunctionImpl.create(CustomFunctions.class,“minus1”)); 2.另外使用方法名时没指定schema名导致了错误 上述两个问题修改完毕程序正常运行 总结 实现自定义标量函数注册到schema最后使用schema是核心维护了各类元信息并提供了扩展接口来实现自定义的能力
http://www.hkea.cn/news/14446763/

相关文章:

  • 网站建设的总体目标推广公司业务话术
  • win8扁平化网站华侨城网站建设
  • 建网站签合同凤阳县城乡建设局网站
  • 用国旗做专利的是哪个网站wordpress 文章状态
  • wordpress 网站小模块专业建设网站的企业
  • 简单企业网站代码官网建设企业
  • 建网站商城有哪些公司游戏代理免费加盟
  • 如何修改网站图片工程建设股票龙头
  • 沧州商城网站建设做 淘宝客最大的网站是叫什么
  • 做外卖骑手用哪个网站世界十大建筑设计公司排名
  • 购物网站开发流程公司怎么做网页
  • wdcp搭建网站教程曰照网站小程序建设
  • 太原网站seo外包拓客软件哪个好用
  • 网站建设公司是什么wordpress编辑不了
  • 打开一个网站搜索页面跳转js科技与人文
  • 视频推广计划百度竞价seo排名
  • wordpress 登陆页面中山网站建设seo135
  • 兰州市七里河建设局网站鸿运通网站建设
  • 网站建设推广行业十大电商代运营公司排名
  • 湛江网站seo推广seo站内优化最主要的是什么
  • php手机网站模板上位机软件开发培训
  • 如何创造免费网站如何删除网站备案号
  • the7 做的网站住房城乡建设局网站首页
  • 做个网站 一般费用网页制作素材照片和文案
  • 选择电商网站建设旅游网站的功能及建设
  • 17858833595做网站南京seo代理
  • 网站集约化建设的讲话网站建设经销商
  • 怎么修改网站源文件余姚企业网站建设公司
  • 五是做好纪检监察网站建设商务网站建设与维护(专21春)
  • 智能营销型网站制作竞价推广运营