达梦数据库-学习-45-JAVA外部函数

达梦数据库-学习-45-JAVA外部函数

目录

一、环境信息

二、说点什么

三、C外部函数链接

四、介绍

1、语法树

2、参数

3、注意点

五、实验步骤

1、开启参数

2、重启数据库服务

3、生成并安装 service.key

4、agent.ini配置

5、启动 dmagent

6、源码

7、编译

8、打Jar包

9、拷贝jar包

10、创建外部函数

11、验证


一、环境信息

名称
CPU12th Gen Intel(R) Core(TM) i7-12700H
操作系统CentOS Linux release 7.9.2009 (Core)
内存7G
逻辑核数8
DM版本DM Database Server 64 V8
DB Version: 0x7000d
03134284368-20250917-293539-20149
Msg Version: 44
Gsu level(5) cnt: 0

二、说点什么

最近工作中有客户经常用到JAVA外部函数,用C外部函数的少之又少,再写一篇记录一下,学无止境。

三、C外部函数链接

C外部函数链接可以参考一下之前的博客。

序号链接
1《达梦数据库-学习-21-C 外部函数》

四、介绍

1、语法树

CREATE [OR REPLACE] FUNCTION [IF NOT EXISTS] [<模式名>.]<函数名>[(<外部函数参数列表>)] RETURN <返回值类型> EXTERNAL '<jar 包路径>' [AND] <引用的 JAVA 函数名>[(<JAVA 函数参数列表>)] USING JAVA; <外部函数参数列表>::=<外部函数参数声明> {,<外部函数参数声明>} <外部函数参数声明>::=<外部函数参数名> [<外部函数参数模式>]<外部函数参数类型> <JAVA 函数参数列表>::=<JAVA 函数参数声明> {,<JAVA 函数参数声明>} <JAVA 函数参数声明>::=<JAVA 函数参数类型> 

2、参数

名称描述
<函数名>被创建的 JAVA 外部函数的名字;
<模式名>被创建的 JAVA 外部函数所属模式的名字,缺省为当前模式名;
<外部函数参数列表>JAVA 外部函数参数信息;
<外部函数参数模式>可设置为 IN、OUT 或 IN OUT(OUT IN),缺省为 IN 类型。参数类型、个数都应和 jar 包里的一致; 
<外部函数参数类型>目前支持的函数参数类型:int、字符串(char、varchar、varchar2)、bigint、double/float/binary_float、binary/varbinary、clob、blob,分别对应 java 类型:int、string、 long、double、byte[]、string、byte[]; 
<返回值类型>必须 jar 包里定义的一致; 
<jar 包路径>用户按照 JAVA 语言格式编写的源码生成的 jar 包,及其依赖的 jar包所在的相对路径或绝对路径;
<引用的 JAVA 函数名><引用的 JAVA 函数名> 指明<函数名>在<jar 包路径>中对应的 JAVA 函数名,函数调用通过 JAVA 反射实现,建议调用函数访问限定符为 public,另外,所属类须不含构造函数或包含无参的构造函数。若<函数名>包含包名,则包名(或.包名)与类名的分隔符要用.或/。而类与方法的分隔符要用.。若不指定<引用函数名>,则后续使用 JAVA 外部函数时会报错。一个正确的 JAVA 函数名示例如下:……EXTERNAL '/data/sda/test.jar' "com.test.package1.test.pass(java.lang.String,java.lang.String[])" USING JAVA;; 
<JAVA 函数参数列表> 用于指定 JAVA 函数的参数列表。缺省情况下,系统自动定位参数。只有未指定<外部函数参数模式>或<外部函数参数模式>中所有参数模式均为IN时,<JAVA 函数参数列表>才可缺省; <JAVA 函数参数声明>由一个或多个<JAVA 函数参数类型>组成。<JAVA 函数参数类型>书写时必须包括 JAVA 类的完整名称。例如:……EXTERNAL '/data/sda/test.jar' "com.test.package1.test.pass(java.lang.String,java.lang.String[])" USING JAVA;。 

3、注意点

序号描述
1当<引用的 JAVA 函数名>[(<JAVA 函数参数列表>)]的长度超过 128 个字节并且不超过 32767 个字节时,不能使用双引号,需要改用单引号括起来,并且需要指定 AND 关键字。例如:EXTERNAL '/data/sda/test.jar' AND 'com.test.package1.test.pass(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String)' USING JAVA; 
2三权分立下,仅允许拥有 DBA 权限的用户创建外部函数;四权分立下,仅允许拥有 DB_OBJECT_ADMIN 权限的用户创建外部函数;
3创建或执行外部函数需要设置 INI 参数 ENABLE_EXTERNAL_CALL 为 1;

五、实验步骤

1、开启参数

[root@rhel709:/root]# cat /dmdata/DAMENG2/dm.ini |grep ENABLE_EXTERNAL_CALL ENABLE_EXTERNAL_CALL = 1 #Whether permit external call

上面这种改文件的,重启不生效,有些奇怪。

SQL> SP_SET_PARA_VALUE(2,'ENABLE_EXTERNAL_CALL',1); DMSQL 过程已成功完成 已用时间: 9.553(毫秒). 执行号:1002.

2、重启数据库服务

[dmdba@rhel709 bin]$ ./DmServiceDM restart

3、生成并安装 service.key

[dmdba@rhel709 dmagent]$ ./start.sh INSTALL_SERVICE_KEY 999999 tip: if using the deployment feature, it is recommended to start dmagent with the '-d' parameter. Agent-V7.6.1.34685-2025.03.26-DEV Key file: "/dm/dmdbms/tool/dmagent/service.key" generated.

4、agent.ini配置

[dmdba@rhel709 dmagent]$ cat agent.ini |grep -E 'ap_enable|ap_port' ap_enable = true #whether enable ap plugin ap_port = 6363 #ap listen tcp/ip port, range[1~65535] [dmdba@rhel709 dmagent]$ pwd /dm/dmdbms/tool/dmagent

agent.ini配置的6363端口需和dm.ini中的EXTERNAL_JFUN_PORT参数一致。

[dmdba@rhel709 dmagent]$ cat /dmdata/DAMENG2/dm.ini |grep EXTERNAL_JFUN_PORT EXTERNAL_JFUN_PORT = 6363 #DmAgent port for external java fun.

5、启动 dmagent

[dmdba@rhel709 dmagent]$ ./start.sh -d agent.ini Starting dmagent..... dmagent(pid: 16039) started successfully.

6、源码

[dmdba@rhel709 DmJar]$ cat test.java package com.test.package1; public class test { public static int testAdd(int a, int b) { return a + b; } public static String testStr(String str) { return str + " hello"; } } 

7、编译

[dmdba@rhel709 DmJar]$ javac -d . test.java

8、打Jar包

[dmdba@rhel709 DmJar]$ jar cvf test.jar com/test/package1/test.class 已添加清单 正在添加: com/test/package1/test.class(输入 = 526) (输出 = 323)(压缩了 38%)

9、拷贝jar包

cp /home/dmdba/DmJar/test.jar /dm/dmdbms/tool/dmagent/resources/ap/

一定要放到这个目录下,不然在执行时会提示如下报错:

SQL> select MY_chr('abc'); [-7094]:外部函数共享库加载失败,错误详情[invalid jar path, jar should under resources/ap directory]. 已用时间: 2.153(毫秒). 执行号:0.

10、创建外部函数

这里建议大家设置相对路径,这样可以避免在集群模式下,多节点目录不一致导致找不到JAR包的问题。

CREATE OR REPLACE FUNCTION MY_INT(a int, b int) RETURN int EXTERNAL 'resources/ap/test.jar' "com.test.package1.test.testAdd" USING java; CREATE OR REPLACE FUNCTION MY_chr(s varchar) RETURN varchar EXTERNAL 'resources/ap/test.jar' "com.test.package1.test.testStr" USING java;

11、验证

SQL> select MY_INT(1,2); 行号 MY_INT(1,2) ---------- ----------- 1 3 已用时间: 0.942(毫秒). 执行号:4505. SQL> select MY_chr('abc'); 行号 MY_CHR('abc') ---------- ------------- 1 abc hello 已用时间: 1.080(毫秒). 执行号:4506.

Read more

C++ 模板编程基础:泛型编程入门与实践

C++ 模板编程基础:泛型编程入门与实践

第33篇:C++ 模板编程基础:泛型编程入门与实践 一、学习目标与重点 * 掌握模板的核心概念、分类(函数模板、类模板)及基本语法 * 理解泛型编程的思想,能够独立编写函数模板和类模板 * 掌握模板的实例化、特化、偏特化等关键技术 * 解决模板使用中的常见问题(类型推导失败、编译错误等) * 结合实际场景运用模板提升代码复用性和灵活性 * 了解模板与STL的关联,为后续STL学习奠定基础 💡 核心重点:模板的语法规则、类型参数与非类型参数的使用、模板特化的应用场景、泛型编程的核心价值 二、模板与泛型编程概述 2.1 什么是泛型编程 泛型编程(Generic Programming)是一种代码复用技术,核心思想是“编写与类型无关的通用代码,在使用时再指定具体类型”,实现“一次编写,多次复用”。 🗄️ 生活中的泛型类比: * 快递盒:同一个快递盒(通用容器)可装手机、书籍、衣物(不同类型数据)

By Ne0inhk
Java Web 汽车票网上预订系统系统源码-SpringBoot2+Vue3+MyBatis-Plus+MySQL8.0【含文档】

Java Web 汽车票网上预订系统系统源码-SpringBoot2+Vue3+MyBatis-Plus+MySQL8.0【含文档】

摘要 随着互联网技术的快速发展,传统汽车票购票方式已无法满足现代用户的便捷性需求。线下购票存在排队时间长、信息不透明、跨区域购票困难等问题,亟需通过信息化手段优化服务流程。汽车票网上预订系统通过整合线上线下资源,为用户提供实时查询、在线选座、电子支付等功能,大幅提升购票效率和用户体验。该系统不仅解决了传统购票模式的痛点,还为交通运营企业提供了数据分析和运营优化的支持,推动行业数字化转型。关键词:汽车票预订、数字化转型、用户体验、线上支付、SpringBoot。 本系统采用前后端分离架构,后端基于SpringBoot2框架搭建,结合MyBatis-Plus实现高效数据操作,MySQL8.0作为主数据库保障数据存储的稳定性和扩展性。前端使用Vue3框架开发,通过Axios与后端交互,实现动态数据渲染和响应式布局。系统核心功能包括用户注册登录、车次查询、在线选座、订单管理、支付接口集成等,同时支持管理员对车辆信息、班次调度、用户行为等数据的可视化分析。系统设计遵循高内聚低耦合原则,确保代码可维护性和可扩展性。关键词:SpringBoot2、Vue3、MyBatis-Plus、MySQL8

By Ne0inhk
Java处理JSON编程实用技巧

Java处理JSON编程实用技巧

1. 前言 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于阅读和编写,同时也易于机器解析和生成。在Java开发中,JSON处理是一项非常常见且重要的任务。本文将详细介绍Java中处理JSON的各种实用技巧,包括主流JSON框架的使用、性能优化以及最佳实践。 本文将重点介绍Gson、Jackson和Fastjson这三个主流Java JSON处理库的使用技巧和性能优化方法。 2. JSON处理框架对比 Java生态中有多个优秀的JSON处理框架,每个框架都有其特点和适用场景。下面是三个主流框架的对比: 3. Gson使用技巧 3.1 基础用法 Gson是Google开发的Java库,用于将Java对象转换为JSON表示,以及将JSON字符串转换回等效的Java对象。 3.1.1 Maven依赖 <dependency> <groupId>com.google.code.gson</groupId> <artifactId>

By Ne0inhk
Spring Boot 3 新特性详解与迁移指南:从 Java 17 到云原生最佳实践

Spring Boot 3 新特性详解与迁移指南:从 Java 17 到云原生最佳实践

Spring Boot 3 新特性详解与迁移指南:从 Java 17 到云原生最佳实践 前言:截至 2026 年 2 月,Spring Boot 3.x 已成为企业级 Java 开发的事实标准。根据最新调研,阿里、字节、腾讯等头部大厂已 100% 完成 Spring Boot 3.2.x 的迁移,3.5.x 作为 3.x 系列的最后一个重大版本,将维护至 2026 年 6 月。然而,从 Spring Boot 2.

By Ne0inhk