溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Hibernate如何使用

發布時間:2021-11-11 09:49:32 來源:億速云 閱讀:114 作者:小新 欄目:數據庫

這篇文章主要介紹Hibernate如何使用,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

  hibernate的來源

  數據在各個層次之間流轉,在流轉過程中會發生數據類型轉換等一系列的交互問題。java與html的交互解決方案是struts2提供的OGNL(對象導航圖語言),而java與數據庫之間的技術解決方案是ORM(對象關系映射)。

  什么是ORM

  對象關系映射:Object relation mapping

  1.對象:指的是java對象,是實體bean

  2.關系:關系只是數據庫,sqlserver,mysql,oracle屬于關系型數據庫,操作關系型數據庫用的是sql語言,但是sql有著明顯的缺點,一次只能執行一條語句,沒有什么基本的邏輯判斷

  3.映射:java中對象的屬性與數據庫中的表字段之間一一對應(包含一對一,一對多,多對一,多對多)。

  ORM需要滿足的條件

  有類屬性和·表字段一一映射的關系

  將關系模型(數據庫)的操作轉化成對對象模型(pojo)的操作

  hibernate的優缺點

  好處:不要程序自己編寫sql,簡化了開發,提高了開發速度,hibernate入門門檻低,上手快。

  缺點:由hibernate自動生成的sql是標準的sql,優化難度大,失去了靈活性,對程序員要求較高,要懂一定的O/R映射。

  快速入手hibernate案列(maven)

  在pom.xml中導入相關的jar’包

  org.hibernate

  hibernate-core

  3.6.5.Final

  如果不能正常創建則需要導入其他包

  <--hibenate核心包-->

  org.hibernate

  hibernate-core

  3.6.8.Final

  <--單元測試包(可不導入)-->

  junit

  junit

  4.7

  test

  <-- Javassit其實就是一個二方包,提供了運行時操作Java字節碼的方法-->

  org.javassist

  javassist

  3.13.0-GA

  <-- 并發訪問處理端口的工具包。-->

  backport-util-concurrent

  backport-util-concurrent

  2.2

  <-- 日志文件包-->

  commons-logging

  commons-logging

  1.1.1

  <--純Java的進程內緩存框架-->

  net.sf.ehcache

  ehcache

  1.2.3

  hibernate.cfg.xml配置文件

  "-//Hibernate/Hibernate Configuration DTD 3.0//EN"

  "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

  oracle.jdbc.driver.OracleDriver

  jdbc:oracle:thin:@localhost:1521:orcl

  scott

  tiger

  none

  org.hibernate.dialect.Oracle10gDialect

  thread

  true

  3.*.xml映射文件

  先寫一個實體bean

  package com.it.bean;

  public class Student {

  private String stu_id;

  private String stu_name;

  private String stu_sex;

  private String stu_birth;

  private String stu_addr;

  public String getStu_id() {

  return stu_id;

  }

  public void setStu_id(String stu_id) {

  this.stu_id = stu_id;

  }

  public String getStu_name() {

  return stu_name;

  }

  public void setStu_name(String stu_name) {

  this.stu_name = stu_name;

  }

  public String getStu_sex() {

  return stu_sex;

  }

  public void setStu_sex(String stu_sex) {

  this.stu_sex = stu_sex;

  }

  public String getStu_birth() {

  return stu_birth;

  }

  public void setStu_birth(String stu_birth) {

  this.stu_birth = stu_birth;

  }

  public String getStu_addr() {

  return stu_addr;

  }

  public void setStu_addr(String stu_addr) {

  this.stu_addr = stu_addr;

  }

  public Student(String stu_id, String stu_name, String stu_sex, String stu_birth, String stu_addr) {

  super();

  this.stu_id = stu_id;

  this.stu_name = stu_name;

  this.stu_sex = stu_sex;

  this.stu_birth = stu_birth;

  this.stu_addr = stu_addr;

  }

  public Student() {

  super();

  // TODO Auto-generated constructor stub

  }

  public Student(String stu_id, String stu_name) {

  super();

  this.stu_id = stu_id;

  this.stu_name = stu_name;

  }

  }

  與之對應的映射文件

  "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

  "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

  dao層的書寫

  BaseDao

  package com.it.dao;

  import java.util.List;

  import org.hibernate.Query;

  import org.hibernate.Session;

  public class BaseDao{

  private Session session;

  public BaseDao(Session session){

  this.session=session;

  }

  public void add(E e){

  session.save(e);

  }

  public void delete(E e){

  session.delete(e);

  }

  public void update(E e){

  session.update(e);

  }

  public List finbBySplit(int currentPage,int currentSize,String hql,String...params){

  Query query=session.createQuery(hql);

  //給問號占位符賦值

  for (int i = 0; i < params.length; i++) {

  query.setString(i, params[i]);

  }

  //分頁參數

  int first=(currentPage-1)*currentSize;

  query.setFirstResult(first);

  query.setMaxResults(currentSize);

  //查詢

  return query.list();

  }

  }

  StudentDao層的書寫

  package com.it.dao;

  import java.util.List;

  import org.hibernate.Session;

  import com.it.bean.Student;

  public class StudentDao extends BaseDao{

  public StudentDao(Session session) {

  super(session);

  // TODO Auto-generated constructor stub

  }

  public void add(Student stu){

  super.add(stu);

  }

  public void delete(Student stu){

  super.delete(stu);

  }

  public void update(Student stu){

  super.update(stu);

  }

  public List find(int currentPage,int currentSize,Student stu){

  String hql="from Student stu where stu.stu_id like ? and stu.stu_name like ? and stu.stu_sex like ? and stu.stu_birth like ? and stu.stu_addr like ? ";

  String []params={"%"+stu.getStu_id()+"%","%"+stu.getStu_name()+"%","%"+stu.getStu_sex()+"%","%"+stu.getStu_birth()+"%","%"+stu.getStu_addr()+"%"};

  return super.finbBySplit(currentPage, currentSize, hql, params);

  }

  }

  此時便可測試了

  @Test

  public void add(){

  SessionFactory sessionFactory=null;

  Session session=null;

  Transaction tx=null;

  try {

  //創建sessionfactory

  sessionFactory=new Configuration().configure().buildSessionFactory();

  //創建session回話---得到線程本身的回話

  session=sessionFactory.getCurrentSession();

  //開啟事務

  tx=session.beginTransaction();

  //添加數據

  Student stu=new Student("0000","沈浪","男","87","北京");

  // session.save(stu);

  //修改數據

  // stu.setStu_name("沈萬三");

  // session.update(stu);

  //刪除數據

  // session.delete(stu);

  //提交事務

  //按照id查詢一條數據

  // Student stu1=(Student)session.get(Student.class, "0000");

  // System.out.println(stu1.getStu_name());

  //hql的使用

  //查詢所有信息

  /*String hql="from Student where stu_id like '%2%'";

  Query query=session.createQuery(hql);

  List list=query.list();

  for (Student student : list) {

  System.out.println(student.getStu_name());

  }*/無錫×××醫院 https://yyk.familydoctor.com.cn/20612/

  //返回vo對象

  /*String hql="select new Student(stu_id,stu_name) from Student where stu_id like '%2%'";

  Query query=session.createQuery(hql);

  List list=query.list();

  for (Student student : list) {

  System.out.println(student.getStu_name());

  }*/

  //返回map類型的參數

  /*String hql="select new map(count(*) as ct,max(stu_id) as maxid) from Student";

  Query query=session.createQuery(hql);

  Map map=(Map)query.uniqueResult();

  System.out.println(map.get("ct"));*/

  //占位符? :

  /*String hql="from Student where stu_id like ?";

  Query query=session.createQuery(hql);

  query.setString(0, "%2%");

  List list=query.list();

  for (Student student : list) {

  System.out.println(student.getStu_name()+"=========");

  }*/

  //:占位符

  /*String hql="from Student where stu_sex=:uid";

  Map params=new HashMap();

  params.put("uid","1");

  Query query=session.createQuery(hql);

  //為參數賦值

  for(String key:params.keySet()){

  System.out.println(key+"==========");

  query.setString(key,params.get(key));

  }

  List list=query.list();

  for (Student student : list) {

  System.out.println(student.getStu_name()+"+++++++");

  }*/

  //返回number類型的參數

  /*String hql="select count(*) from Student";

  Query query=session.createQuery(hql);

  Number ct=(Number)query.uniqueResult();

  System.out.println(ct.intValue());*/

  //模糊搜素

  /*Student stu1=new Student("1","武");

  String[] params={"%"+stu1.getStu_id()+"%","%"+stu1.getStu_name()+"%"};

  String hql="from Student where stu_id like ? and stu_name like ?";

  // String hql="from Student where stu_id like '%1%' and stu_name like '%武%'";

  Query query=session.createQuery(hql);

  //為?號賦值

  for (int i = 0; i < params.length; i++) {

  query.setString(i,params[i]);

  System.out.println(params[i]);

  }

  System.out.println(hql);

  System.out.println(query.list().size());*/

  //hibernate分頁

  String hql="from Student where stu_id like '%2%'";

  Query query=session.createQuery(hql);

  int currentPage=1;

  int pageSize=4;

  int startPage=(currentPage-1)*pageSize;

  query.setFirstResult(startPage); //開始顯示的位置

  query.setMaxResults(pageSize); //顯示最大數據數

  System.out.println(query.list().size());

  tx.commit();

  } catch (Exception e) {

  // TODO: handle exception

  e.printStackTrace();

  //事務回滾

  tx.rollback();

  }

  }

  此刻一個簡單的demo變創建成功了

以上是“Hibernate如何使用”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女