gpt4 book ai didi

java - 将数组从 Java 传递到 Oracle : java. sql.SQLException:无法转换为内部表示:错误

转载 作者:搜寻专家 更新时间:2023-11-01 01:00:49 26 4
gpt4 key购买 nike

我在 DAO 中有以下内容,当我执行时,我得到了

java.sql.SQLException: Fail to convert to internal representation: test.Project@843

DAO 代码

List projectList = new LinkedList();

public void saveRecord(List<Project> project)
throws DatabaseException,SQLException {

for (Project items: project) {
insertRecord(items);
}
}

private void insertRecord(Project project) throws SQLException {
projectList.add(project);
try{
ArrayDescriptor desc =
ArrayDescriptor.createDescriptor("MY_ARRAY", dbConn);

// execpetion in this line
ARRAY arr = new ARRAY(desc, dbConn, (Object[])projectList.toArray());

我该如何解决这个问题?

编辑 1

CREATE OR REPLACE TYPE project_type as object( 
proj_id varchar2 (10),
proj_title varchar2 (10));


create or replace type my_array as Table of project_type;

最佳答案

不幸的是,这比人们想象的要复杂。您必须使用 STRUCT 对象、描述符,最后是 ARRAY。下面是一个工作示例。

-- Database code --

CREATE TABLE project_types (
proj_id VARCHAR2(10),
proj_title VARCHAR2(10)
);
/

CREATE OR REPLACE TYPE project_type AS OBJECT (
proj_id VARCHAR2(10),
proj_title VARCHAR2(10)
);
/

CREATE OR REPLACE TYPE my_array AS TABLE OF project_type;
/

CREATE OR REPLACE PROCEDURE add_projects(p_projects_array IN my_array)
AS
BEGIN
IF p_projects_array IS NOT NULL THEN
FOR v_i IN 1..p_projects_array.LAST
LOOP
INSERT INTO project_types
VALUES (p_projects_array(v_i).proj_id,
p_projects_array(v_i).proj_title);
END LOOP;
END IF;
END;
/
// Java code - main class

import java.sql.Connection;
import java.sql.DriverManager;

import oracle.jdbc.OracleCallableStatement;
import oracle.jdbc.OracleConnection;
import oracle.sql.ARRAY;
import oracle.sql.ArrayDescriptor;
import oracle.sql.STRUCT;
import oracle.sql.StructDescriptor;

public class ArrayExampleMain {

public static void main(String[] args) throws Exception {
OracleConnection conn = getOracleConnection().unwrap(OracleConnection.class);
System.out.println("Got Connection.");

OracleCallableStatement callStmt = null;

try {
callStmt = (OracleCallableStatement)conn.prepareCall("{call add_projects(?)}");

// create array holding values for ProjectType object's properties
Object[] project1 = new Object[] {"1", "Title 1"};
Object[] project2 = new Object[] {"2", "Title 2"};

// descriptor for OBJECT type defined in database
StructDescriptor projectTypeDesc = StructDescriptor.createDescriptor("PROJECT_TYPE", conn);

// each struct is one ProjectType object
STRUCT structProject1 = new STRUCT(projectTypeDesc, conn, project1);
STRUCT structProject2 = new STRUCT(projectTypeDesc, conn, project2);

STRUCT[] structArrayOfProjects = {structProject1, structProject2};

// descriptor of TABLE type defined in database
ArrayDescriptor projectTypeArrayDesc = ArrayDescriptor.createDescriptor("MY_ARRAY", conn);

// array holding two ProjectType objects
ARRAY arrayOfProjects = new ARRAY(projectTypeArrayDesc, conn, structArrayOfProjects);

callStmt.setARRAY(1, arrayOfProjects);
callStmt.execute();
conn.commit();

System.out.println("Committed.");
} catch (Exception e) {
if (conn != null) try { conn.rollback(); } catch (Exception ex) { System.out.println("Rollback failed."); }
throw e;
} finally {
callStmt.close();
conn.close();
}
}

public static Connection getOracleConnection() throws Exception {
String driver = "oracle.jdbc.driver.OracleDriver";
String url = "jdbc:oracle:thin:@YOUR_HOST:orcl";
String username = "hr";
String password = "password";

Class.forName(driver); // load Oracle driver

Connection conn = DriverManager.getConnection(url, username, password);

return conn;
}
}

主类执行后检查project_types表的内容:

SELECT * FROM project_types;

输出:

PROJ_ID    PROJ_TITLE---------- ----------1          Title 1    2          Title 2

关于java - 将数组从 Java 传递到 Oracle : java. sql.SQLException:无法转换为内部表示:错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19888520/

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