哇,我发现忙起来真的是没有时间来写,最近在学框架,感觉特别有兴趣,对于框架的感激就是又恨又爱的感觉,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的底层浅谈的更多相关文章

  1. 【Hibernate 7】浅谈Hibernate的缓存机制

    一.Hibernate缓存机制简介 对于Hibernate本身来说,它的缓存主要包括三部分:session缓存(一级缓存).二级缓存.查询缓存. 1.1,session缓存 随着session的关闭而 ...

  2. Hibernate更新部分字段浅谈

    update语句是在Hibernate的Configuration的时候生成的,不能动态改变.为什么update的时候所有的属性都一起update,而不是只更新改变字段,其实这是一个比较值得探讨的问题 ...

  3. !! 浅谈Java学习方法和后期面试技巧

    浅谈Java学习方法和后期面试技巧 昨天查看3303回复33 部落用户大酋长 下面简单列举一下大家学习java的一个系统知识点的一些介绍 一.java基础部分:java基础的时候,有些知识点是非常重要 ...

  4. 浅谈 Java 主流开源类库解析 XML

    在大型项目编码推进中,涉及到 XML 解析问题时,大多数程序员都不太会选用底层的解析方式直接编码. 主要存在编码复杂性.难扩展.难复用....,但如果你是 super 程序员或是一个人的项目,也不妨一 ...

  5. [转帖]浅谈IOC--说清楚IOC是什么

    浅谈IOC--说清楚IOC是什么 Need Study https://www.cnblogs.com/DebugLZQ/archive/2013/06/05/3107957.html 博文目录 1. ...

  6. 浅谈Hybrid技术的设计与实现第三弹——落地篇

    前言 接上文:(阅读本文前,建议阅读前两篇文章先) 浅谈Hybrid技术的设计与实现 浅谈Hybrid技术的设计与实现第二弹 根据之前的介绍,大家对前端与Native的交互应该有一些简单的认识了,很多 ...

  7. 浅谈Hybrid技术的设计与实现第二弹

    前言 浅谈Hybrid技术的设计与实现 浅谈Hybrid技术的设计与实现第二弹 浅谈Hybrid技术的设计与实现第三弹——落地篇 接上文:浅谈Hybrid技术的设计与实现(阅读本文前,建议阅读这个先) ...

  8. 浅谈Hybrid技术的设计与实现

    前言 浅谈Hybrid技术的设计与实现 浅谈Hybrid技术的设计与实现第二弹 浅谈Hybrid技术的设计与实现第三弹——落地篇 随着移动浪潮的兴起,各种APP层出不穷,极速的业务扩展提升了团队对开发 ...

  9. Spring缓存框架原理浅谈

    运维在上线,无聊写博客.最近看了下Spring的缓存框架,这里写一下 1.Spring 缓存框架 原理浅谈 2.Spring 缓存框架 注解使用说明 3.Spring 缓存配置 + Ehcache(默 ...

随机推荐

  1. win10 uwp 右击浮出窗在点击位置

    本文主要让MenuFlyout出现在我们右击位置. 我们一般使用的MenuFlyout写在前台,写在Button里面,但是可能我们的MenuFlyout显示的位置和我们想要的不一样. 通过使用后台写S ...

  2. STM32F10x -- 利用IIC协议操作AT24C02

    关于AT24C02芯片的一些参数性能可参考其他的一些相关资料.此处只贴出程序. 宏文件AT24CXX.h #ifndef _AT24CXX_H_ #define _AT24CXX_H_ #includ ...

  3. Java设计模式(四)——再谈观察者模式

    在本系列的上一篇文章中,我们讨论了JDK对于观察者模式的一套实现.今天我们将要从另一个角度来探索Tomcat中是如何利用观察者模式加载各个组件.不过今天的任务不是解释Tomcat,所以我会单独把重点抽 ...

  4. CSS3动画 transition和animation的用法和区别

    transition和animation都是CSS3新增的特性,使用时需要加内核 浏览器 内核名称 W3C   IE  -ms-  Chrome/Safari -webkit-   Firefoc - ...

  5. mysql的并发处理机制_下篇

        MySQL的并发处理机制,有MVCC及锁机制来处理,上篇简要说明了 MVCC及隔离级别,这篇来说说mysql下的锁.     温馨提示:下文有几个表格长度较长,右下角的博文导航目录会挡道,浏览 ...

  6. 62、django之MTV模型(urls,view)

    今天就进入到python最重要的阶段了django框架,框架就像胶水一样会将我们前面学的所有知识点粘合在一起,所以以前有哪些部分模糊的可以看看前面的随笔.本篇主要介绍djangoMTV模型,视图层之路 ...

  7. mysql安装教程以及配置快捷方式

    1.首先双击exe 3.Next 安装过程省略.... Win+r 然后输入:cmd 打开dos窗口后: 输入: mysql -uroot -p你设置的密码 案例:mysql -uroot -proo ...

  8. 测试服务搭建之centos7下安装java

    一 安装Java 1 创建普通用户 useradd wujian passwd wujian 提示输入密码:[输入wujian的密码] user:wujian group:root passwd:12 ...

  9. 读书笔记-你不知道的JS中-函数生成器

    这个坑比较深 可能写完我也看不懂(逃 ES6提供了一个新的函数特性,名字叫Generator,一开始看到,第一反应是函数指针?然而并不是,只是一个新的语法. 入门 简单来说,用法如下: functio ...

  10. T9

    T9 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission ...