做爲SSH中的重要一環,有必要理解一下Hibernate對 O/R Mapping的實現。java
主要利用java的反射機制來獲得完整的SQL語句。mysql
準備工做:sql
1. Objectapp
Student實體類:ui
public class Student { private int id; private String name; private int age; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
2. Relationshipthis
_student表:spa
-- database: hibernate create table _student(_id int primary key auto_increment,_age int,_name varchar(20));
3. 模擬O/R Mapping:hibernate
針對Student實體類的SessionStu (完成Student對象的持久化):code
public class SessionStu { private String tableName; private Map<String, String> field2Column = new HashMap<String,String>(); private String[] fields; public SessionStu() { // 如下內容應當經過解析xml的方式build出來 // 該示例僅僅演示Hibernate的核心部分:O/R Mapping (利用反射獲得完整sql) tableName = "_student"; field2Column.put("id","_id"); field2Column.put("name","_name"); field2Column.put("age","_age"); fields = new String[field2Column.size()]; try { Class.forName("com.mysql.jdbc.Driver"); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } public void save(Student student) throws Exception { // TODO Auto-generated method stub String sql = createSQL(); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/hibernate","root",""); PreparedStatement ps = conn.prepareStatement(sql); ps = setParameters(ps,student); ps.executeUpdate(); ps.close(); conn.close(); } //important private PreparedStatement setParameters(PreparedStatement ps, Student student) throws Exception{ for (int i = 0; i < fields.length; i++) { String get_method = "get"+(char)(fields[i].charAt(0)-32)+fields[i].substring(1); Method m = student.getClass().getMethod(get_method); String type = m.getReturnType().getName(); String te = type.substring(type.lastIndexOf(".")+1); switch (te) { case "int": ps.setInt(i+1, (int) m.invoke(student)); break; case "String": ps.setString(i+1, (String) m.invoke(student)); default: break; } } return ps; } private String createSQL(){ String columnsStr = ""; int index = 0; for (String key : field2Column.keySet()) { fields[index] = key; columnsStr += (field2Column.get(key) + ","); index++; } columnsStr = columnsStr.substring(0, columnsStr.length()-1); String unknow = ""; for (int i = 0; i < field2Column.size(); i++) { unknow += "?,"; } unknow = unknow.substring(0,unknow.length()-1); String sql = "insert into " + this.tableName + " (" + columnsStr +") values (" + unknow +")"; System.out.println(sql); return sql; } }
4. Test:xml
public class TestSessionSave { public static void main(String[] args) throws Exception { Student student = new Student(); student.setAge(20); student.setId(5); student.setName("hibernate"); SessionStu ss = new SessionStu(); ss.save(student); } }
5. Done