このような学生クラス用の MySQL ストアド プロシージャを作成しました。このストアド プロシージャを Hibernate で呼び出したいと思います。
ストアド プロシージャ:
DELIMITER $$
DROP PROCEDURE IF EXISTS `StudentProcedure`$$
CREATE PROCEDURE `StudentProcedure`(IN studentNo varchar(12) )
BEGIN
SELECT SNAME FROM Student WHERE SNO=studentNo;
END$$
DELIMITER ;
私のPojoクラス:
package edu.model;
public class Student {
private String studentNo;
private String studentName;
public String getStudentNo() {
return studentNo;
}
public void setStudentNo(String studentNo) {
this.studentNo = studentNo;
}
public String getStudentName() {
return studentName;
}
public void setStudentName(String studentName) {
this.studentName = studentName;
}
}
HBM ファイル:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="edu.model.Student" table="Student">
<id name="studentNo" column="SNO">
<generator class="assigned"/>
</id>
<property name="studentName">
<column name="SNAME" />
</property>
</class>
<sql-query name="StudentProcedure" callable="true">
<return alias="student" class="edu.model.Student">
<return-property name="studentName" column="SNAME">
</return-property>
</return>
<![CDATA[CALL StudentProcedure(:studentNo)]]>
</sql-query>
</hibernate-mapping>
テストクラス:
package edu.test;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import edu.model.Student;
import edu.util.SessionUtil;
public class ProcedureTest {
public static void main(String args[]) {
Session session = SessionUtil.getSession();
Transaction tx = session.beginTransaction();
try {
Query query = session.getNamedQuery("StudentProcedure");
System.out.println("Test");
query.setParameter("studentNo","123");
Student student = (Student)query.uniqueResult();
System.out.println("Student Name:" + student.getStudentName());
} catch (HibernateException e) {
System.err.println("Hibernate Exception>>>"+e.getClass().getName()+"..........+"+e.getMessage());
tx.rollback();
}
}
}
My class を実行すると、以下の例外に直面しています:
SEVERE: Column 'SNO0_0_' not found.
Hibernate Exception>>>org.hibernate.exception.SQLGrammarException..........+could not execute query
誰でも私を助けてくれますか