日期:2014-05-20 浏览次数:20630 次
/******
* @introduce:
* 1、这个类是Hibernate中模拟Session的部分
* 2、这个类,由于有些部分与问题无关,
* 为了不影响阅读,我这里把与问题相关的核心部分发出来!
*/
public class MySession {
String tableName = "_Students";//表名
Map<String , String> cfg = new HashMap<String , String>();//<表字段名,实体属性名>
String[] mName;//将实体中getXxx()用数组表示
private Student s;
//初始化
public MySession(){//这是MySession的构造函数
cfg.put("_id", "id");
cfg.put("_name", "name");
cfg.put("_age", "age");
mName = new String[cfg.size()];
}
public void save(Student s)throws Exception
{
String sql = createSQL();
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","system","weidu23");
PreparedStatement pst = conn.prepareStatement(sql);
for(int i =0 ; i <mName.length;i++)
{
String m = mName[i];
Method methodName = s.getClass().getMethod(m);
Class<?> returnType = methodName.getReturnType();
if( returnType.getName().equals("int"))
{
pst.setInt(i+1, (Integer)methodName.invoke(s));
}
else if(returnType.getName().equals("java.lang.String"))
{
pst.setString(i+1, (String)methodName.invoke(s));
}
else if(returnType.getName().equals("java.sql.Date"))
{
pst.setDate(i+1,(java.sql.Date)methodName.invoke(s));
}
else
;
}
pst.executeQuery();
pst.close();
pst.close();
}
private String createSQL() {
//SQL:insert into _Students(_id,_age,_name) values(?,?,?)
//str1代表的是【_id,_age,_name】部分
String str1 = "" ;
int index = 0 ;
for(String s:cfg.keySet()){
str1 += s+"," ;
String v = cfg.get(s);
String m = "get" + Character.toUpperCase(v.charAt(0)) + v.substring(1);
mName[index] = m ;
index++;
}
str1 = str1.substring(0, str1.length()-1);
System.out.println(str1);
//str2代表的是【?,?,?】部分
String str2 = "";
//拼接str2
for(int i=0;i<cfg.size();i++){
str2 += "?"+",";