




已阅读5页,还剩6页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
大致课程安排Hibernateday01 、hibernate人门(hibernate操作数据 查询、新增、删除、修改)1回顾:jdbc操作数据库1创建表person id 主键name 姓名age 年龄status 是否删除状态 0表示有效,1表示已删除状态2创建web项目3创建实体类(pojo、Entity)Person类int idString nameint ageString statuspackage com.chinasofti.pojo;import java.io.Serializable;SuppressWarnings(serial)public class Person implements Serializable private Integer id;private String name;private int age;private String status;public Person()public Person(String name, int age, String status) super(); = name;this.age = age;this.status = status;public Integer getId() return id;public void setId(Integer id) this.id = id;public String getName() return name;public void setName(String name) = name;public int getAge() return age;public void setAge(int age) this.age = age;public String getStatus() return status;public void setStatus(String status) this.status = status;4写获得Connection的JdbcUtil类package com.chinasofti.util;import java.io.IOException;import java.io.InputStream;import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;import java.util.Properties;public class JdbcUtil private static String driver;private static String url;private static String username;private static String password;private static ThreadLocal tlc = new ThreadLocal();/静态代码块staticProperties prop = new Properties();/perties 文件与JdbcUtil在同一目录下InputStream inStream = JdbcUtil.class.getResourceAsStream(perties);try prop.load(inStream);driver = prop.getProperty(driver);url = prop.getProperty(url);username = prop.getProperty(user);password = prop.getProperty(password); catch (IOException e) e.printStackTrace();public static Connection getConnection()/从ThreadLocal对象中获得与当前线程绑定的连接Connection con = tlc.get();if(con=null)try /加载mysql驱动包Class.forName(driver);/获得一个新的数据库的连接con = DriverManager.getConnection(url, username, password); catch (Exception e) e.printStackTrace();return con;public static void closeConnection(Connection con)if(con!=null)try con.close(); catch (SQLException e) e.printStackTrace();5创建Dao类 Dao是用来操作数据库数据的对象package com.chinasofti.dao;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.util.ArrayList;import java.util.List;import com.chinasofti.pojo.Person;import com.chinasofti.util.JdbcUtil;public class PersonDao public List findPersons()List persons = new ArrayList();/获得数据库连接Connection con = JdbcUtil.getConnection();/创建预编译Sql语句,防止SQL注入String sql = select * from tbl_person;try PreparedStatement prs = con.prepareStatement(sql);/执行sql语句,查询数据库ResultSet rs = prs.executeQuery();/把从数据库中查询到的数据封装到Person对象中Person p = null;while(rs.next()p = new Person();p.setId(rs.getInt(id);p.setName(rs.getString(name);p.setAge(rs.getInt(age);p.setStatus(rs.getString(status);persons.add(p); catch (SQLException e) e.printStackTrace();return persons;5创建测试类TestJdbc类,测试连接是否成功获取package com.chinasofti.test;import java.sql.Connection;import java.util.List;import org.junit.Test;import com.chinasofti.dao.PersonDao;import com.chinasofti.pojo.Person;import com.chinasofti.util.JdbcUtil;public class TestJdbc Testpublic void test1()Connection con = JdbcUtil.getConnection();System.out.println(con);Testpublic void test2()PersonDao dao = new PersonDao();List ps = dao.findPersons();for(Person p:ps)System.out.println(p.getId()+,+p.getName();2hibernate:orm关联关系映射框架1创建web项目2导入hibernate的jar包3配置hibernate.cfg.xml主配置文件4创建实体类与实体类映射文件Person.hbm.xmlcom.mysql.jdbc.Driverrootrootorg.hibernate.dialect.MySQL5Dialecttruefalsethread5创建HibernateUtil类,获得Hibernate中的Sessionpackage com.chinasofti.util;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.cfg.Configuration;public class HibernateUtil private static SessionFactory sessionFactory;static/加载hibernate主配置文件Configuration cfg = new Configuration();cfg.configure(hibernate.cfg.xml);/创建hibernate的session工厂sessionFactory = cfg.buildSessionFactory();public static Session getHibernateSession()/获得与当前线程绑定的hibernate的session/*thread*/Session session = sessionFactory.getCurrentSession();return session;public void closeHibernateSession(Session session)if(session!=null)session.close();6创建实体类及实体类映射文件package com.chinasofti.pojo;import java.io.Serializable;SuppressWarnings(serial)public class Person implements Serializable private Integer id;private String name;private int age;private String status;public Person()public Person(String name, int age, String status) super(); = name;this.age = age;this.status = status;public Integer getId() return id;public void setId(Integer id) this.id = id;public String getName() return name;public void setName(String name) = name;public int getAge() return age;public void setAge(int age) this.age = age;public String getStatus() return status;public void setStatus(String status) this.status = status;Person.hbm.xml文件内容7创建测试类:package com.chinasofti.test;import java.util.List;import org.hibernate.Session;import org.hibernate.Transaction;import org.junit.Test;import com.chinasofti.dao.PersonDao;import com.chinasofti.pojo.Person;import com.chinasofti.util.HibernateUtil;public class HibernateTest Testpublic void test1()Session session = HibernateUtil.getHibernateSession();System.out.println(session);Testpublic void test2()PersonDao dao = new PersonDao();List ps = dao.findPersons();for(Person p:ps)System.out.println(p.getId()+,+p.getName()+,+p.getStatus();/* * Session: * servlet中的Session是一次会话,就是指浏览器与服务器之间的通信 * Hibernate的Session是一个连接,就是指我们的应用程序与数据库之间的一个连接 * * 通过主键id获得数据库数据 * get()当id对应的数据不存在的时候返回null * load()当id对应的数据不存在的时候抛出异常 * org.hibernate.OjbectNotFoundException: * No row with the given identifier exists * * 延迟加载的问题: * * 修改和新增: */Testpublic void test3()/获得hibernate的连接Session session = HibernateUtil.getHibernateSession();/开启事务Transaction tx = session.beginTransaction();/执行查询/get()立刻加载 Person p = (Person) session.get(Person.class,1);/延迟加载/Person p = (Person) session.load(Person.class,1);System.out.println(p);/提交事务mit();if(p!=null)System.out.println(p.getId()+,+p.getName();Hibernate: select person0_.id as id0_,person0_.name as name0_, person0_.age as age0_, person0_.status as status0_ from test.tbl_person person0_ where person0_.status=0对象Seesion理解:Session分两种:Servlet中的Session和Hibernate中的Session有什么区别?Servlet中的Session是指浏览器访问服务器的时候,在服务器中创建的浏览器与服务器之间的一个会话。默认浏览器关
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 不良资产处置行业市场格局洞察报告:2025年创新模式应用前景展望
- 2025年新初二英语人教新版尖子生专题复习《短文填空》
- 小学生碘缺乏课件
- 新能源物流车推广应用与物流行业新能源技术应用与产业创新趋势分析策略报告
- 保税综合仓库管理办法
- 临时就业人员管理办法
- 临沂产业用地管理办法
- 住宅装修质量管理办法
- 信息公司采购管理办法
- 乡镇医疗物资管理办法
- 2025至2030中国医疗头戴式显示器行业产业运行态势及投资规划深度研究报告
- 枪支安全管理培训课件
- 浙江省丽水市普通高中2024-2025学年高二上学期期末教学质量监控日语试卷(PDF版含答案不含音频和听力原文)
- 2025至2030电子海图行业产业运行态势及投资规划深度研究报告
- 小程序公司推广活动方案
- 公交车消防课件
- 厂家促销活动以旧换新活动方案
- 2025年湖北省中考英语试题(附答案)
- 2025中国系统性红斑狼疮诊疗指南解读课件
- 成人重症患者颅内压增高防控护理专家共识
- 2025年网络安全与信息保护基础知识考试题及答案
评论
0/150
提交评论