簡體   English   中英

如何從plsql中的存儲過程獲取java代碼中的結果集

[英]How to get a resultset in java code, from a stored procedure in plsql

我正在使用MVC模式我有兩個表:Employee和Address

說,員工就像

-------------------
Id  | Name   | DeptId
-------------------
101 | Jake   | 501  
102 | Donald | 502

我有一個像這樣的部門表

-----------------------------
DeptId | Name | Description
-----------------------------
501    | IT   | software assistance  
502    | HR   | Human resources

現在,因為我使用MVC,這些表被映射到類

@Table(name="Employee")
Class Employee{
   @Id
   @Column(name="Id")
   private Long id;

   @Column(name="Name")
   private String name;

   @Column(name="DeptId")
   private Long deptId;

   @ManyToOne
   @JoinColumn(name="DeptId", referencedColumnName="id", insertable=false,updatable=false)
   private Department dept;

   //getters and setters go here
}

和其他類部門(映射到部門表)

@Table(name="Department")
    Class Department{
       @Id
       @Column(name="Id")
       private Long id;

       @Column(name="Name")
       private String name;

       @Column(name="Description")
       private String description;

       //getters and setters go here
    }

請注意,Employee類引用了Department類的對象。 這個@ManyToOne和@JoinColumn注釋幫助我們自動檢索相應的部門對象以及員工對象

它很容易直接在代碼中查詢,但如果我只在我的代碼中使用過程或函數我怎么能這樣做我嘗試了不同的方法,但它似乎沒有幫助

有時我得到的錯誤類似於Cannot return resultset from a stored procedure in oracle 10g

任何人都可以澄清一下。 我也必須使用JNDI

我可以從過程/函數中獲取我的結果,它返回給我List<Employee> (不是我自己必須整理到對象中的原始結果集)。 應該可以使用hibernate no嗎?

謝謝

您的PLSQL需要返回引用游標

JPA 2.1支持將CallableStatement將游標映射到實體。 看到這個答案

我正在寫偽代碼(不是工作示例。)但它應該解決你的問題。

神諭

CREATE OR REPLACE PROCEDURE getEmployees(deptName varchar(20))
BEGIN
   SELECT * FROM Employee where DeptId in ( select DeptId from Department where Name =deptName );

END;
/

過冬

Query query = session.createSQLQuery(
    "CALL GetStocks(:getEmployees)")
    .addEntity(Employee.class)
    .setParameter("deptName", "Production");

List result = query.list();
for(int i=0; i<result.size(); i++){
    Employee emp = (Employee)result.get(i);
    System.out.println(emp.toString());
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM