我是靠谱客的博主 笑点低冰淇淋,这篇文章主要介绍java 数组传入sql语句,如何从Java列表创建SQL数组?,现在分享给大家,希望可以做个参考。

我正在尝试在表中插入一个数组,但我需要将列表转换为SQL数组类型.我正在使用Connection#createArrayOf()方法,但我得到了一个例外.

我需要传递一个类型名称,但我不知道这是什么,我总是得到一个例外.该数组来自VARCHAR.

我如何解决这个插入数组?

代码

Object[] array = new Object[token.getCategories().size()];

array = token.getCategories().toArray();

pstmTokenInsert.setArray(1, conn.createArrayOf("VARCHAR", array));

堆栈跟踪

org.postgresql.util.PSQLException: Could not find array type for data type VARCHAR

at org.postgresql.jdbc4.AbstractJdbc4Connection.createArrayOf(AbstractJdbc4Connection.java:73)

at org.postgresql.jdbc4.Jdbc4Connection.createArrayOf(Jdbc4Connection.java:21)

at org.apache.commons.dbcp.DelegatingConnection.createArrayOf(DelegatingConnection.java:560)

at br.ifsp.da.data.TokenDAO.insertTokens(TokenDAO.java:37)

at br.ifsp.da.data.ProcessedPageInserter.loopInsertion(ProcessedPageInserter.java:44)

at br.ifsp.da.data.ProcessedPageInserter.call(ProcessedPageInserter.java:27)

at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)

at java.util.concurrent.FutureTask.run(FutureTask.java:166)

at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)

at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)

at java.lang.Thread.run(Thread.java:722)

最后

以上就是笑点低冰淇淋最近收集整理的关于java 数组传入sql语句,如何从Java列表创建SQL数组?的全部内容,更多相关java内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(68)

评论列表共有 0 条评论

立即
投稿
返回
顶部