对于Hibernate的底层浅谈
哇,我发现忙起来真的是没有时间来写,最近在学框架,感觉特别有兴趣,对于框架的感激就是又恨又爱的感觉,hibernate,没有研究太深,模拟的写了一点底层的实现,其实就是发射吧,我没有追踪源码去看,就是简单的模拟,哈哈哈,反射出原始类型的没有写现在再追struts的底层,上次我还信誓旦旦的说,年前能写25篇,现在想说我错了,哈哈哈哈
好了,代码就写了一点,都是我猜的,如果有不对的,大神们求带
public class Session {
private static Map<String,String> map = new HashMap<String,String>();
private static final String driver = "com.mysql.jdbc.Driver";
private static final String url = "jdbc:mysql://localhost:3306/demo";
private static final String username = "root";
private static final String password = "0610";
//模拟底层save
public void save(Object obj) throws Exception{
String sql = generateSQL(obj);//调用生成sql语句的方法
System.out.println(sql);//打印sql语句
Class.forName(driver);
Connection conn = (Connection) DriverManager.getConnection(url, username, password);
PreparedStatement ps = (PreparedStatement) conn.prepareStatement(sql);
Set<String> keys = map.keySet();
int i = 1;//表示占位符的索引
for (String key : keys) {
//获取属性对应的get方法
Method m = obj.getClass().getMethod(map.get(key));
//通过反射调用get方法获取属性的值,作为占位符的值
ps.setObject(i, m.invoke(obj));
i++;//占位符+1
}
ps.executeUpdate();//指定插入语句
}
/**
* 生成sql语句的方法
* insert into 表名(列名,列名,...) values(?,?,...)
* @param obj
* @return
* @throws SecurityException
* @throws NoSuchMethodException
*/
public static String generateSQL(Object obj) throws Exception{
//获取实体类中所有的属性
Field[] fields = obj.getClass().getDeclaredFields();
//向map中存放键值对:键是属性名,也就是列名;值是属性get方法的名字
for(int i = 0;i < fields.length;i++){
map.put(fields[i].getName(), "get" +fields[i].getName().substring(0, 1).toUpperCase() + fields[i].getName().substring(1));
}
String columns = "";//存储列名
String values = "";//存储?
Set<String> keys = map.keySet();
for (String key : keys) {
columns = columns + key + ",";//拼接列名
values = values + "?,";
}
//截取最后的逗号
if(columns.endsWith(",")){
columns = columns.substring(0, columns.length()-1);
values = values.substring(0,values.length()-1);
}
//获取实体类的表名
String tName = obj.getClass().getSimpleName();
//拼接sql语句
String sql = "insert into " + tName + "(" + columns + ") values(" + values + ")";
return sql;
}
//根据id生成sql语句
public String selectById(Class objClass) throws Exception{
//生成一个对象,
Constructor<?> construction =objClass.getConstructor();
Object object=construction.newInstance();
//获得所有的属性,
Field[] fields = objClass.getDeclaredFields();
for(int i = 0;i < fields.length;i++){
map.put(fields[i].getName(), "set" +fields[i].getName().substring(0, 1).toUpperCase() + fields[i].getName().substring(1));
}
String columns = "";//存储列名
Set<String> keys = map.keySet();
for (String key : keys) {
columns = columns + key + ",";//拼接列名
}
//所有的属性的名字,
if(columns.endsWith(",")){
columns = columns.substring(0, columns.length()-1);
}
//获取实体类的表名
String tName = objClass.getSimpleName();
//拼接sql语句
String sql = " select " + columns + " from "+ tName +" where mid =? ";
return sql;
}
//根据class对象和id进行查询
public Object get(Class<?> objClass,Long id) {
Constructor<?> cons=null;
Object obj=null;
try {
cons = objClass.getConstructor();
obj=cons.newInstance();
String sql = selectById(objClass);//调用生成sql语句的方法
System.out.println(sql);//打印sql语句
Class.forName(driver);
Connection conn = (Connection) DriverManager.getConnection(url, username, password);
PreparedStatement ps = (PreparedStatement) conn.prepareStatement(sql);
//执行方法进行获得结果集
ps.setObject(1, id);
//进行查询
ResultSet rs = ps.executeQuery();
while(rs.next()){
//对对象进行封装
Set<String> keys = map.keySet();
for (String key : keys) {
Object o= rs.getObject(key);
Method m = objClass.getMethod(map.get(key),new Class<?>[]{o.getClass()});
//执行对象的set方法
m.invoke(obj,o);
}
}
System.out.println(obj);
} catch (Exception e) {
}
return obj;
}
//根据id进行删除
public void delete(Object obj){
//根据id进行删除
Class objClass=obj.getClass();
String sql="";
//获取对象的id
Field[] fields = objClass.getDeclaredFields();
for(int i=0;i<fields.length;i++){
if("mid".equalsIgnoreCase(fields[i].getName())){
//进行执行删除操作
String name = objClass.getSimpleName();
//获得该属性的值,
String setterName="get" +fields[i].getName().substring(0, 1).toUpperCase() + fields[i].getName().substring(1);
//获得getter的方法
Method method;
try {
method = objClass.getMethod(setterName);
Object id = method.invoke(obj);
sql=" delete from "+name+" where mid= ? ";
System.out.println(sql);
Class.forName(driver);
Connection conn = (Connection) DriverManager.getConnection(url, username, password);
PreparedStatement ps = (PreparedStatement) conn.prepareStatement(sql);
//执行方法进行获得结果集
ps.setObject(1, id);
ps.executeUpdate();
System.out.println("删除成功");
}catch (Exception e) {
e.printStackTrace();
}
}
}
}
//删除main方法测试
public static void main(String[] args) {
Session session=new Session();
Object object = session.get(Customer.class, 1L);
session.delete(object);
}
/*//查询main方法进行测试
public static void main(String[] args) {
Session session =new Session();
try {
Object object = session.get(Customer.class, 1L);
} catch (Exception e) {
e.printStackTrace();
}
}*/
//添加的测试
/*public static void main(String[] args) throws Exception {
Session session = new Session();
Customer customer = new Customer();
customer.setMid(1111L);
customer.setName("阿里巴巴");
customer.setAddress("杭州");
session.save(customer);
}
*/
}
对于Hibernate的底层浅谈的更多相关文章
- 【Hibernate 7】浅谈Hibernate的缓存机制
一.Hibernate缓存机制简介 对于Hibernate本身来说,它的缓存主要包括三部分:session缓存(一级缓存).二级缓存.查询缓存. 1.1,session缓存 随着session的关闭而 ...
- Hibernate更新部分字段浅谈
update语句是在Hibernate的Configuration的时候生成的,不能动态改变.为什么update的时候所有的属性都一起update,而不是只更新改变字段,其实这是一个比较值得探讨的问题 ...
- !! 浅谈Java学习方法和后期面试技巧
浅谈Java学习方法和后期面试技巧 昨天查看3303回复33 部落用户大酋长 下面简单列举一下大家学习java的一个系统知识点的一些介绍 一.java基础部分:java基础的时候,有些知识点是非常重要 ...
- 浅谈 Java 主流开源类库解析 XML
在大型项目编码推进中,涉及到 XML 解析问题时,大多数程序员都不太会选用底层的解析方式直接编码. 主要存在编码复杂性.难扩展.难复用....,但如果你是 super 程序员或是一个人的项目,也不妨一 ...
- [转帖]浅谈IOC--说清楚IOC是什么
浅谈IOC--说清楚IOC是什么 Need Study https://www.cnblogs.com/DebugLZQ/archive/2013/06/05/3107957.html 博文目录 1. ...
- 浅谈Hybrid技术的设计与实现第三弹——落地篇
前言 接上文:(阅读本文前,建议阅读前两篇文章先) 浅谈Hybrid技术的设计与实现 浅谈Hybrid技术的设计与实现第二弹 根据之前的介绍,大家对前端与Native的交互应该有一些简单的认识了,很多 ...
- 浅谈Hybrid技术的设计与实现第二弹
前言 浅谈Hybrid技术的设计与实现 浅谈Hybrid技术的设计与实现第二弹 浅谈Hybrid技术的设计与实现第三弹——落地篇 接上文:浅谈Hybrid技术的设计与实现(阅读本文前,建议阅读这个先) ...
- 浅谈Hybrid技术的设计与实现
前言 浅谈Hybrid技术的设计与实现 浅谈Hybrid技术的设计与实现第二弹 浅谈Hybrid技术的设计与实现第三弹——落地篇 随着移动浪潮的兴起,各种APP层出不穷,极速的业务扩展提升了团队对开发 ...
- Spring缓存框架原理浅谈
运维在上线,无聊写博客.最近看了下Spring的缓存框架,这里写一下 1.Spring 缓存框架 原理浅谈 2.Spring 缓存框架 注解使用说明 3.Spring 缓存配置 + Ehcache(默 ...
随机推荐
- Django(二)
QuerySet与惰性机制: 所谓惰性机制:Publisher.objects.all()或者所谓惰性机制:Publisher.objects.all()或者.filter()等都只是返回了一个Que ...
- JPA + SpringData 操作数据库原来可以这么简单 ---- 深入了解 JPA - 3
原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7718741.html ------------------------------------ ...
- Single Number2
题目链接:http://oj.leetcode.com/problems/single-number-ii/ Given an array of integers, every element app ...
- (转)UML实践详细经典教程----用例图、顺序图、状态图、类图、包图、协作图
原文链接:http://dn.codegear.com/article/31863 面向对象的问题的处理的关键是建模问题.建模可以把在复杂世界的许多重要的细节给抽象出.许多建模工具封装了UML(也就是 ...
- js正则验证特殊字符
js正则验证特殊字符 方案一 var regEn = /[`~!@#$%^&*()_+<>?:"{},.\/;'[\]]/im, regCn = /[·!#¥(--):: ...
- 数据帧CRC32校验算法实现
本文设计思想采用明德扬至简设计法.由于本人项目需要进行光纤数据传输,为了保证通信质量要对数据进行校验.在校验算法中,最简单最成熟的非CRC校验莫属了. 得出一个数的CRC校验码还是比较简单的: 选定一 ...
- Spring MVC前后端的数据传输
本篇文章主要介绍了Spring MVC中如何在前后端传输数据. 后端 ➡ 前端 在Spring MVC中这主要通过Model将数据从后端传送到前端,一般的写法为: @RequestMapping(va ...
- 机器翻译评测——BLEU算法详解
◆版权声明:本文出自胖喵~的博客,转载必须注明出处. 转载请注明出处:http://www.cnblogs.com/by-dream/p/7679284.html 前言 近年来,在自然语言研究领域中, ...
- .xlsx文件总是默认用2007 Microsoft Office component 打开,且无法更改用EXCEL打开的解决方法
之前装了OFFICE2003,后来改装了 OFFICE2007,之后XLSX文件双击总是用2007 Microsoft Office component 打开,导致无法打开. 解决方法: 打开注册表R ...
- python web框架篇:views视图函数
Django请求的生命周期是怎样的? 简单地说,通过URL对应关系匹配 ->找到对应的函数(或者类)->返回字符串(或者读取Html之后返回渲染的字符串) 解剖起来如下: 1. 当用户在浏 ...