JDBC支持Struct解决了人大金仓数据库KingbaseES应用兼容接口不支持Struct的问题

关键字

JDBC、Struct、人大金仓、kingbase

问题描述

应用可以通过JDBC接口使用Struct功能。

问题分析

应用端缺少JDBC接口支持Struct功能。

解决方案

在使用JDBC(Java Database Connectivity)操作Kes数据库时,可以使用JDK标准提供的Struct接口,操作的示例代码:

ini 复制代码
PreparedStatement pstmt = conn.prepareStatement("INSERT INTO compositeTable VALUES(?, ?)");
Object[] attributes1 = new Object[3];
attributes1[0] = 1;
attributes1[1] = 2.2;
Struct struct1 = conn.createStruct("simplecompositetest", attributes1);

pstmt.setObject(1, struct1);
String[] ctArr = new String[2];
ctArr[0] = "(1,2.2,)";
ctArr[1] = "(2,4.2,)";
Array pgarr1 = conn.createArrayOf("simplecompositetest", ctArr);
pstmt.setArray(2, pgarr1);
int res = pstmt.executeUpdate();
assertEquals(1, res);
pstmt = conn.prepareStatement("SELECT * FROM compositeTable");
ResultSet rs = pstmt.executeQuery();
assertTrue(rs.next());
Struct pgo2 = (Struct) rs.getObject(1);
compareResultSet("simplecompositetest", pgo2);
Array pgarr2 = (Array) rs.getObject(2);
assertEquals("simplecompositetest", pgarr2.getBaseTypeName());
Object[] pgobjarr2 = (Object[]) pgarr2.getArray();
assertEquals(2, pgobjarr2.length);
Struct arr2Elem = (Struct) pgobjarr2[0];
compareResultSet("simplecompositetest", arr2Elem);
rs.close();

这些示例展示了如何使用kes的JDBC的Struct功能。您可以根据自己的需求进行适当的调整和扩展。

参考资料

《KingbaseES客户端编程接口指南-JDBC.pdf》

相关推荐
ㄟ留恋さ寂寞5 分钟前
Golang怎么限制请求Body大小_Golang如何防止客户端发送过大的请求体【避坑】
jvm·数据库·python
老纪15 分钟前
CSS Flex布局中如何实现导航栏与Logo的左右分布_利用justify-content- space-between
jvm·数据库·python
会编程的土豆17 分钟前
Go ini 配置加载:`ini.MapTo` 详细解析
开发语言·数据库·golang
今天也是元气满满的一天呢25 分钟前
详解SQL注入问题
网络·数据库·sql
omenkk727 分钟前
【MySQL专题】1.一条更新SQL语句是如何执行的
数据库·sql·mysql
2301_8092445330 分钟前
mysql如何处理大量重复值索引_mysql索引存储特征分析.txt
jvm·数据库·python
Lehjy37 分钟前
【MySQL】库的操作
数据库·mysql·oracle
2401_8844541538 分钟前
如何管理只读表空间的备份_跳过只读表空间的RMAN优化策略
jvm·数据库·python
Languorous.39 分钟前
MySQL CRUD实操详解:插入、查询、修改、删除,附可直接运行示例
数据库·mysql
woxihuan12345644 分钟前
CSS移动端实现响应式导航菜单_利用媒体查询切换显示隐藏状态
jvm·数据库·python