gpt4 book ai didi

postgresql - 使用 ARRAY 输出类型从 PostgreSQL 过程生成 JOOQ

转载 作者:行者123 更新时间:2023-11-29 13:01:39 25 4
gpt4 key购买 nike

当使用 JOOQ(3.5.1) 生成 java 代码时,如果过程有一个带有数组类型字段的表返回类型,我会得到空指针异常。

CREATE OR REPLACE FUNCTION func1(IN param1 integer)
RETURNS TABLE(result1 integer, result2 integer[]) AS
....

生成器错误:

Error while generating table record public.func1     
java.lang.NullPointerException
at org.jooq.impl.DefaultDataType.getDataType(DefaultDataType.java:637)
at org.jooq.impl.DefaultDataType.getDataType(DefaultDataType.java:828)
at org.jooq.impl.DefaultDataType.getType(DefaultDataType.java:841)
at org.jooq.util.JavaGenerator.getType(JavaGenerator.java:3220)
at org.jooq.util.JavaGenerator.getType(JavaGenerator.java:3185)
at org.jooq.util.JavaGenerator.getType(JavaGenerator.java:3194)
at org.jooq.util.JavaGenerator.getJavaType(JavaGenerator.java:3173)
at org.jooq.util.JavaGenerator.getJavaType(JavaGenerator.java:3169)
at org.jooq.util.JavaGenerator.getRowType(JavaGenerator.java:935)
at org.jooq.util.JavaGenerator.generateRecord(JavaGenerator.java:700)
at org.jooq.util.JavaGenerator.generateRecord(JavaGenerator.java:659)
at org.jooq.util.JavaGenerator.generateRecords(JavaGenerator.java:648)
at org.jooq.util.JavaGenerator.generate(JavaGenerator.java:309)
at org.jooq.util.JavaGenerator.generate(JavaGenerator.java:247)
at org.jooq.util.GenerationTool.run(GenerationTool.java:402)
at org.jooq.util.GenerationTool.main(GenerationTool.java:167)
at org.jooq.util.GenerationTool$main.call(Unknown Source)
at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:45)
at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:108)
at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:116)

最佳答案

This is a bug in jOOQ 3.5.1并将在 jOOQ 3.6.0 和 3.5.2 中修复。

关于postgresql - 使用 ARRAY 输出类型从 PostgreSQL 过程生成 JOOQ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28410929/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com