db2set DB2_RESTRICT_DDF=TRUE

本文分析了com.ibm.db2.jcc.am.SqlException错误的具体原因,该错误提示操作无效:已关闭resultset。通过堆栈跟踪详细说明了问题发生的上下文,并提出了两种解决方案:一是调整JDBC驱动的progressiveStreaming属性值;二是在服务端执行特定命令并重启数据库。
com.ibm.db2.jcc.am.SqlException: [jcc][t4][10120][10898][3.63.123] 操作无效:已关闭 result set。 ERRORCODE=-4470, SQLSTATE=null
at com.ibm.db2.jcc.am.fd.a(fd.java:663)
at com.ibm.db2.jcc.am.fd.a(fd.java:60)
at com.ibm.db2.jcc.am.fd.a(fd.java:103)
at com.ibm.db2.jcc.am.vn.Db(vn.java:4528)
at com.ibm.db2.jcc.am.vn.r(vn.java:1822)
at com.ibm.db2.jcc.am.vn.getMetaData(vn.java:1814)
at org.pentaho.di.core.database.Database.getOneRow(Database.java:3505)
at org.pentaho.di.repository.Repository.getIDWithValue(Repository.java:1093)
at org.pentaho.di.repository.Repository.getTransformationID(Repository.java:952)
at org.pentaho.di.trans.TransMeta.<init>(TransMeta.java:2472)
at org.pentaho.di.trans.TransMeta.<init>(TransMeta.java:2442)
at org.pentaho.di.ui.trans.dialog.TransLoadProgressDialog$1.run(TransLoadProgressDialog.java:77)
at org.eclipse.jface.operation.ModalContext.runInCurrentThread(ModalContext.java:369)
at org.eclipse.jface.operation.ModalContext.run(ModalContext.java:313)
at org.eclipse.jface.dialogs.ProgressMonitorDialog.run(ProgressMonitorDialog.java:495)
at org.pentaho.di.ui.trans.dialog.TransLoadProgressDialog.open(TransLoadProgressDialog.java:89)
at org.pentaho.di.ui.spoon.Spoon.loadLastUsedFile(Spoon.java:5679)
at org.pentaho.di.ui.spoon.Spoon.handleStartOptions(Spoon.java:5532)
at org.pentaho.di.ui.spoon.Spoon.start(Spoon.java:5555)
at org.pentaho.di.ui.spoon.Spoon.main(Spoon.java:412)
ERROR 20-08 23:04:20,066 - Transformation 1 - A database error occured reading a transformation from the repository
org.pentaho.di.core.exception.KettleException: 
This file doesn't exist : Transformation 1

解决方法为:设置JDBC驱动的progressiveStreaming属性值为2或在服务端执行“db2set DB2_RESTRICT_DDF=TRUE”命令并重启数据库。

`void *__restrict__` 是 C 语言中一种带有 **`restrict`** 关键字修饰的指针类型,常见于标准库函数的参数中,例如: ```c void *memcpy(void *__restrict__ dest, const void *__restrict__ src, size_t n); ``` --- ## ✅ `void *__restrict__` 的含义 ### 1. `void *` - 表示一个指向**任意类型**的指针; - 在 `memcpy()` 等函数中,表示可以复制任意类型的数据; - 不关心具体数据类型,只按字节操作。 ### 2. `__restrict__` - 是 C99 标准引入的关键字 `restrict` 的一种编译器特定写法(有些编译器使用 `__restrict__`); - 用于告诉编译器:**这个指针是访问其所指向对象的唯一方式**; - 编译器可以据此进行更激进的优化,比如不进行内存重读或缓存中间结果。 ### 🔁 举例说明: ```c void foo(int *a, int *b, int *c) { for (int i = 0; i < 100; i++) { a[i] = b[i] + c[i]; } } ``` 如果 `a`、`b`、`c` 有重叠,编译器无法优化,因为每次写入 `a[i]` 可能影响 `b[i]` 或 `c[i]`。 但如果写成: ```c void bar(int * __restrict__ a, int * __restrict__ b, int * __restrict__ c) { for (int i = 0; i < 100; i++) { a[i] = b[i] + c[i]; } } ``` 编译器就知道:`a`、`b`、`c` 指向的内存**不会重叠**,可以放心优化,比如用寄存器缓存值、向量化指令等。 --- ## ✅ 在 `memcpy()` 中的使用意义 ```c void *memcpy(void *__restrict__ dest, const void *__restrict__ src, size_t n); ``` - `dest` 和 `src` 是两个不会重叠的内存区域; - 如果重叠,行为是未定义的; - 如果你使用 `memcpy()` 拷贝重叠内存,应该使用 `memmove()` 替代。 --- ## ✅ `__restrict__` 和 `restrict` 的区别 | 关键字 | 标准 | 说明 | |--------------|------|------| | `restrict` | C99/C11/C17 | 标准关键字 | | `__restrict__` | GNU、TI、IAR 等编译器扩展 | 与 `restrict` 等价,用于兼容性 | --- ## ✅ 示例代码(使用 `restrict`) ```c #include <stdio.h> void add(int * restrict a, int * restrict b, int * restrict result) { *result = *a + *b; } int main() { int x = 3, y = 4, z; add(&x, &y, &z); printf("z = %d\n", z); return 0; } ``` --- ## ✅ 注意事项 - `restrict` 是给编译器的提示,不是运行时检查; - 如果你违反 `restrict` 的语义(比如传入重叠的指针),程序行为是**未定义**的; - 在高性能嵌入式、HPC、图像处理等场景中非常有用。 --- ##
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值