//封装实体类
package common.dao;
public class BookDao {
private Integer bookId;
private String bookName;
private String bookAuth;
private int bookCount;
public Integer getBookId() {
return bookId;
}
public void setBookId(Integer bookId) {
this.bookId = bookId;
}
public String getBookName() {
return bookName;
}
public void setBookName(String bookName) {
this.bookName = bookName;
}
public String getBookAuth() {
return bookAuth;
}
public void setBookAuth(String bookAuth) {
this.bookAuth = bookAuth;
}
public int getBookCount() {
return bookCount;
}
public void setBookCount(int bookCount) {
this.bookCount = bookCount;
}
}
package common.dao;
public class CarDao {
private Integer carId;
private String carName;
private Double carPrice;
public Integer getCarId() {
return carId;
}
public void setCarId(Integer carId) {
this.carId = carId;
}
public String getCarName() {
return carName;
}
public void setCarName(String carName) {
this.carName = carName;
}
public Double getCarPrice() {
return carPrice;
}
public void setCarPrice(Double carPrice) {
this.carPrice = carPrice;
}
}
//hbm,xml基本配置
<?xml version="1.0" encoding="UTF-8"?>
<mapping>
<class name="common.dao.BookDao" table="t_user">
<id name="bookId">
<generator class="increment"></generator>
<property name="bookName" column="book_Name"></property>
<property name="bookAuth" column="book_Auth"></property>
<property name="bookcount" column="book_Count"></property>
</id>
</class>
</mapping>
//有两种配置方式
package dao;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.Map;
import common.dao.BookDao;
import common.dao.CarDao;
public class TestDao {
/* public void save(Object obj) throws Exception{
Class<? extends Object> clazz = obj.getClass();
//System.out.println(clazz);
String name = clazz.getName();
Field field = clazz.getDeclaredField(name);
//getsimpleName 获得类 的名称 获取类
String tableName = clazz.getSimpleName();
//System.out.println(tableName+" 1");
StringBuffer hql =new StringBuffer();
hql.append(" insert into "+tableName);
//System.out.println(clazz.getName()+" 2");
Field[] fields = clazz.getDeclaredFields();
StringBuffer value1=new StringBuffer();
StringBuffer value=new StringBuffer();
for (Field field : fields) {
value1.append(","+field.getName());
//获取权限 1-5 2代表私有的 getName 类里面的字段 getType字段的数据类型
//System.out.println(field.getModifiers()+"======"+field.getName()+"====="+field.getType());
Method method = clazz.getMethod(makeMethodName(field.getName()), null);
//System.out.println(method.getName());
Object invoke = method.invoke(obj, null);
System.out.println(method.getName()+":"+invoke);
if(invoke.getClass().getSimpleName().equals("String")){
invoke="‘"+invoke+"‘";
}
value.append(","+invoke);
}
//System.out.println(value.substring(1));
Method[] methods = clazz.getMethods();
for (Method method : methods) {
System.out.println(method +" 3");
}
hql.append(" ( "+value1.toString().substring(1)+" )");
hql.append(" values("+value.toString().substring(1)+" )");
System.out.println(hql.toString());
}
//拼接私有化的get对象方法
private String makeMethodName(String fieldName) {
return "get"+fieldName.substring(0,1).toUpperCase()+fieldName.substring(1);
}*/
private static Map<String, Object> mapping = new HashMap<String, Object>();
static {
mapping.put("common.dao.BookDao", "t_book");
mapping.put("bookId", "book_Id");
mapping.put("bookName", "book_Name");
mapping.put("bookAuth", "book_Auth");
mapping.put("bookCount", "book_Count");
}
public static void save(Object obj) throws Exception{
//System.out.println(mapping.get("common.dao.BookDao"));
Class<? extends Object> clazz = obj.getClass();
String tableName = (String) mapping.get(clazz.getName());
StringBuffer sql = new StringBuffer("insert into ");
System.out.println(tableName);
if(tableName==null||"".equals(tableName)){
throw new Exception("对不起访问的实体对象不存在 "+obj.getClass().getSimpleName() );
}
//System.out.println(tableName);
sql.append(tableName);
StringBuffer valueName = new StringBuffer();
StringBuffer value= new StringBuffer();
Field[] fields = clazz.getDeclaredFields();
for (Field field : fields) {
// System.out.println(field.getName());
// System.out.println(mapping.get(field.getName()));
Method method = clazz.getMethod(MakeMathodName(field.getName()), null);
// System.out.println(method);
Object invoke = method.invoke(obj, null);
// System.out.println(invoke);
if(invoke.getClass().getSimpleName().equals("String")){
invoke="‘"+invoke+"‘";
}
valueName.append(","+mapping.get(field.getName()));
value.append(","+invoke);
}
sql.append(" ("+valueName.substring(1)+")");
sql.append(" values ("+value.substring(1)+")");
System.out.println(sql);
}
private static String MakeMathodName(String fieldName) {
//System.out.println("get"+fieldName.substring(0,1).toUpperCase()+fieldName.substring(1));
return "get"+fieldName.substring(0,1).toUpperCase()+fieldName.substring(1);
}
public static void main(String[] args) throws Exception {
CarDao car = new CarDao();
car.setCarId(1);
car.setCarName("法拉利");
car.setCarPrice(12.5);
BookDao book = new BookDao();
book.setBookId(2);
book.setBookName("骆驼祥子");
book.setBookCount(1000);
book.setBookAuth("老舍");
TestDao testDao = new TestDao();
save(car);
save(book);
}
/*完成反射机制的三个条件 getClass 获取类的路径 */
/* public void save(Object obj) throws Exception{
// StringBuffer sql = new StringBuffer();
// Class<? extends Object> clazz = obj.getClass();
// String tableName = clazz.getSimpleName();
// sql.append("insert into "+tableName+" values (");
//// System.out.println(clazz.getName());
//// System.out.println(clazz.getSimpleName());
//// 获得类中的所有属性,课后作业:这个方法能不能获得继承的属性。
// Field[] fields = clazz.getDeclaredFields();
// StringBuffer values = new StringBuffer();
// for (Field field : fields) {
//// System.out.println(field.getModifiers() + ":" + field.getType() +":"+field.getName());
// Method method = clazz.getMethod(makeMethodName(field.getName()),null);
//// System.out.println(method.getName());
//// invoke表示动态调用当前方法,方法两个参数:调用谁的method,方法的参数值
// Object value = method.invoke(obj, null);
//// System.out.println(value);
// if(value.getClass().getSimpleName().equals("String")){
// value = "‘" + value + "‘";
// }
// values.append(value + ",");
// }
// sql.append(values.toString().substring(0,values.toString().length()-1));
// sql.append(")");
// System.out.println(sql.toString());
// }
//
// fieldName --> userName; getUserName()
public String makeMethodName(String fieldName){
return "get" + fieldName.substring(0,1).toUpperCase() + fieldName.substring(1);
}
public static void main(String[] args) throws Exception {
HibernateDAO hibernateDAO = new HibernateDAO();
UserDTO user = new UserDTO();
user.setId(1);
user.setUserName("admin");
user.setUserPwd("aaa");
user.setAge(21);
hibernateDAO.save(user);
BookDTO book = new BookDTO();
book.setId(21);
book.setBookName("西游记");
book.setPrice(20.00);
hibernateDAO.save(book);
}
public void save(Object obj) throws Exception{
StringBuffer sql = new StringBuffer();
sql.append("insert into ");
Class<? extends Object> clazz = obj.getClass();
String tableName = (String)mapping.get(clazz.getName());
if(tableName == null || tableName.equals("")){
throw new Exception("对不起,没有关于" + obj.getClass().getSimpleName() + "的hbm映射");
}
sql.append(tableName);
System.out.println(tableName);
sql.append(" (");
Field[] fields = clazz.getDeclaredFields();
StringBuffer values = new StringBuffer();
for (int i = 0; i < fields.length; i++) {
Field filed = fields[i];
Method method = clazz.getMethod(MakeMathodName(filed.getName()),null);
Object value = method.invoke(obj, null);
if(value.getClass().getSimpleName().equals("String")){
value = "‘"+value+"‘";
}
if(i == fields.length-1){
sql.append(mapping.get(filed.getName()));
values.append(value);
}else{
sql.append(mapping.get(filed.getName()) + ",");
values.append(value + ",");
}
}
sql.append(") values (");
sql.append(values.toString());
sql.append(")");
System.out.println(sql.toString());
}
*/
}
//百度百科
原文:http://www.cnblogs.com/wjh-93-3-1/p/7224126.html