package com.quan.hibernate.model;
import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
/**
* Session的模拟
*/
public class create {
String url = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=hibernate";
String user = "sa";
String password = "123";
String tableName = "_Student";
Map<String,String> cfs = new HashMap<String, String>();
String[] methodNames;
public create() {
cfs.put("_id", "id");
cfs.put("_name","name");
cfs.put("_age", "age");
methodNames = new String[cfs.size()];
}
public void save(Student s) throws Exception {
String sql = createSQL();
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
Connection conn = DriverManager.getConnection(url, user, password);
PreparedStatement ps = conn.prepareStatement(sql);
for(int i = 0; i<methodNames.length;i++) {
Method m = s.getClass().getMethod(methodNames[i]);
Class r= m.getReturnType();
if(r.getName() == "java.lang.String") {
String returnValue = (String)m.invoke(s);
ps.setString(i+1, returnValue);
}
if(r.getName() == "int") {
Integer returnValue = (Integer)m.invoke(s);
ps.setInt(i+1, returnValue);
}
}
/*for(int i = 0; i<cfs.size(); i++) {
ps.setXXX(s.getXXX);
}*/
ps.executeUpdate();
ps.close();
conn.close();
}
private String createSQL() {
String str1 = "";
String str2 = "";
int index = 0;
for(String s : cfs.keySet()) {
String v = cfs.get(s);
v= Character.toUpperCase(v.charAt(0)) + v.substring(1);
methodNames[index] = "get" + v;
str1 += s + ",";
}
str1 = str1.substring(0, str1.length()-1);
for(int i = 0; i<cfs.size();i++) {
str2 += "?,";
}
str2 = str2.substring(0, str2.length()-1);
String sql = "insert into "+tableName+"("+str1+")"+"valses ("+str2+")";
return sql;
}
}
分享到:
相关推荐
刚学习了hibernate,就简单模拟了hibernate中session的save(Object obj)方法。使用方法跟原版一样,同样需要写hibernate.cfg.xml和实体类的映射文件,通过dom4j读取配置文件的内容,再使用反射技术拼成动态的sql语句...
在深入理解Hibernate的工作机制时,可以通过模拟的方式重现其内部逻辑。以下是一个简化的示例,展示Hibernate如何将Java对象持久化到数据库中: 1. **SQL语句构建**:当调用`session.save()`时,Hibernate会根据...
- 使用反射技术为PreparedStatement的参数赋值。 - 执行SQL更新操作。 2. Hibernate简介: - Hibernate是一个开源的ORM框架,提供了对JDBC的轻量级封装,让开发者以对象编程的方式处理数据库操作。 - Hibernate...
至于`lib`目录,通常包含了一系列Hibernate 3.3运行所需的依赖库,这些库涵盖了JDBC驱动、日志框架(如log4j)、XML解析器、反射增强工具等。例如,JDBC驱动用于与各种数据库进行通信,log4j提供日志记录服务,DOM4J...
本项目旨在实现一个基于JDK5.0注解的小型ORM框架,模拟Hibernate的部分功能。 首先,我们要理解ORM的基本原理。ORM的核心思想是将数据库中的表映射为Java对象,将表中的记录映射为对象的实例,这样就可以通过操作...
8. **反射机制**:解释反射的概念及其在运行时动态获取类信息的功能。 9. **新版本Java语言特性**:介绍Java新版本中的特性和改进点,如Lambda表达式、Stream API等。 #### 四、JavaEE中的数据存储 1. **XML**:...
20. **虚拟主机**:在一台物理服务器上模拟多个独立的服务器环境,提高硬件利用率。 21. **Java虚拟机(JVM)**:Java程序的运行环境,负责类加载、运行字节码、内存管理等。 22. **JVM生命周期与体系结构**:包括...
- **Spring+Hibernate如何使用Session、Query等对象**:在Spring配置文件中定义SessionFactory,然后在DAO层中通过@Autowired等方式获取Session对象,进行数据库操作。 - **Spring框架和Struts2整合应用**:Spring...
{3.3}String常量重利用}{70}{section.3.3} {3.4}正则表达式}{71}{section.3.4} {3.5}StringBuffer}{75}{section.3.5} {3.6}StringBuilder}{76}{section.3.6} {3.7}StringBuilder与StringBuffer的缺点}{76}{...
- **NIO (Non-blocking I/O)**: 同步非阻塞I/O模型,使用单线程或多线程来管理多个连接,利用选择器(selector)机制来检查多个通道(channel)的状态,从而减少线程的开销。 - **AIO (Asynchronous I/O)**: 异步非...
最后,模拟Spring的实现将帮助我们理解Spring的内部工作原理,比如如何通过反射创建bean,如何解析和加载bean的配置信息,以及如何实现AOP的动态代理等。这种实践过程不仅加深了对Spring的理解,也为日常开发中的...
最大限度利用编译器减少编码错误的可能性 API设计和元数据模型(meta-model)的使用,使得常规的数据库查询都可以直接通过Criteria API来完成,无需使用任何JPQL/HQL/SQL。可以让避免用户犯一些语法、拼写等错误。...
- **准备策略**:提前准备并模拟面试场景。 ### 腾讯面试/阿里面试 - **面试流程**:包括技术面试、HR面试等环节。 - **面试技巧**:强调团队合作和个人成就。 ### 安卓签到精灵app - **功能**:实现自动签到。 ...