亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Hibernate 入門

2019-11-18 13:55:34
字體:
來源:轉載
供稿:網友

Hibernate 入門(原創) 2004/08/22
作者:雨傘(geezer)

----------------------------------------------

本文配置環境:
JBuilder X
jdk 1.4.2
MySQL 4.0.11 驅動:mm.mysql-2.0.4-bin.jar(org.gjt.mm.mysql.Driver)
Hibernate 2.1

解壓Hibernate

打開JB,新建工程,名為:hibernate
加入Hibernate需要的包與MYSQL驅動
步驟:file->new PRoject->name中輸入hibernate,Directory選擇你要存放本工程的路徑->next

->required libraries->add->new->name中輸入你要設置的hibernate包名

->add->選擇你hibernate解壓到的目錄,選中該目錄下的hibernate2.jar與lib目錄下的所有jar包,再把你的MYSQL驅動包也加進去

然后一直按OK,next。

新建一個類,名為Hello_Bean.java,代碼如下:



package hibernate;

import java.io.Serializable;

/**
* @author geezer
* QQ:9986986 MSN:geezer_hot@hotmail.com
*/

public class Hello_Bean implements Serializable {

private String name;//這里name與address和id的名字可以自己定,不會有什么影響.但get與set方法不可以。因為那得跟數據庫與配置文件對應。

private String address;

private int id;



public Hello_Bean() {

}

public Hello_Bean(String name, String address) {//構造函數,看完本章以后相信你會明白的了
this.name = name;
this.address = address;
}

public String getName() {//此方法名必須與Hello_Bean.hbm.xml文件里的對應的名字一樣,下面會具體講
return name;
}

public void setName(String name) {
this.name = name;
}

public String getAddress() {
return address;
}

public void setAddress(String address) {
this.address = address;
}

public int getId() {//必須的方法
return id;
}

public void setId(int id)//必須的方法
{
this.id = id;
}


}



完成這一步以后編譯

將hibernate解壓后的目錄下的src文件夾里的hibernate.properties與log4j.properties文件復制到你的工程目錄的classes目錄下

(例如hibernateclasses目錄下),

打開hibernate.properties文件,找到

## HypersonicSQL

hibernate.dialect net.sf.hibernate.dialect.HSQLDialect
hibernate.connection.driver_class org.hsqldb.jdbcDriver
hibernate.connection.username sa
hibernate.connection.passWord
hibernate.connection.url jdbc:hsqldb:hsql://localhost
hibernate.connection.url jdbc:hsqldb:test
hibernate.connection.url jdbc:hsqldb:.

改為

## HypersonicSQL

#hibernate.dialect net.sf.hibernate.dialect.HSQLDialect
#hibernate.connection.driver_class org.hsqldb.jdbcDriver
#hibernate.connection.username sa
#hibernate.connection.password
#hibernate.connection.url jdbc:hsqldb:hsql://localhost
#hibernate.connection.url jdbc:hsqldb:test
#hibernate.connection.url jdbc:hsqldb:.

再找到

## MySQL

#hibernate.dialect net.sf.hibernate.dialect.MySQLDialect
#hibernate.connection.driver_class org.gjt.mm.mysql.Driver
#hibernate.connection.driver_class com.mysql.jdbc.Driver
#hibernate.connection.url jdbc:mysql:///test
#hibernate.connection.username root
#hibernate.connection.password

改為


## MySQL

hibernate.dialect net.sf.hibernate.dialect.MySQLDialect
hibernate.connection.driver_class org.gjt.mm.mysql.Driver
hibernate.connection.url jdbc:mysql://localhost:3306/test
hibernate.connection.username root
hibernate.connection.password

上面的URL請改為你自己的

完成以后創建一個空的文件,保存在你工程的類文件同個文件夾里(例如hibernateclasseshibernate目錄下),文件名為:Hello_Bean.hbm.xml

內容如下:



<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 2.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">
<hibernate-mapping>

<class name="hibernate.Hello_Bean" table="test_hibernate" >

<id name="id" column="id">

<generator class="identity"/>

</id>

<property name="name" type="string" update="true" insert="true" column="name" />
<property name="address" type="string" update="true" insert="true" column="address" />

</class>

</hibernate-mapping>



稍微解釋一下,<class name="hibernate.Hello_Bean" table="test_hibernate" >里的name指你的生成表的類,

table則指定你要創建的數據庫表的名字,可以自由修改,沒有影響.

<id name="id" column="id">設置主鍵ID,這里name的值id跟Hello_Bean.java里的方法getId與setId對應,不用管這個,hibernate會自動調用,配置好就可以了,column的值為要生成的字段名,可以自由修改,沒有影響。

<generator class="identity"/>屬性讓主鍵的ID自增(插入數據的時候自動加1)

<property name="name" type="string" update="true" insert="true" column="name" />這里的name值"name"跟Hello_Bean.java里的getName方法對應,column為要生成的字段名
<property name="address" type="string" update="true" insert="true" column="address" />

分別添加一個字段name與address,注重這里的type屬性類型為string,假如這里的類型與Hello_Bean.java里設置的類型不一樣會出錯。

修改完以后保存。

最后在JB里新建一個類,名字為Hello.java,我會一步步解釋,代碼如下:



package hibernate;

import net.sf.hibernate.cfg.Configuration;
import net.sf.hibernate.sessionFactory;
import net.sf.hibernate.tool.hbm2ddl.SchemaEXPort;
import net.sf.hibernate.Session;
import net.sf.hibernate.Query;
import net.sf.hibernate.Hibernate;
import net.sf.hibernate.type.LongType;
import net.sf.hibernate.Transaction;
import net.sf.hibernate.ScrollableResults;
import java.util.*;

/**
* @author geezer
* QQ:9986986 MSN:geezer_hot@hotmail.com
*/


public class Hello {


public Hello() {


}

public static void main(String[] args) throws Exception {

Configuration cfg = new Configuration().addClass(Hello_Bean.class);//用Hello_Bean.class類初始化

SessionFactory sessions = cfg.buildSessionFactory();//用buildSessionFactory方法得到一個SessionFactory對象

Session session = sessions.openSession();//再用SessionFactory的openSession方法得到一個session



new SchemaExport(cfg).create(true, true);//這句意思是創建表,第一次運行以后,就是創建完表以后再把這行加上注釋。假如建表以后不把這一句注釋掉的話會刪掉以前創建的表再重新建一個。




Hello_Bean my_hibernate = new Hello_Bean();//得到一個Hello_Bean對象

my_hibernate.setName("my_name");//設置Hello_Bean對象的name值為my_name,這里其實就是說把字符串my_name當作數據庫字段name的值.數據庫字段name與Hello_Bean類里的getName,setName方法是對應的。形成一個映射關系。

my_hibernate.setAddress("my_address");//如上

session.save(my_hibernate);//這句很重要,將my_hibernate對象寫進數據庫(my_hibernate對象里的name與address我們剛剛已經設置了值了,會直接把name,address的值寫進數據庫去)

session.flush();
session.close();


//上面是一個簡單的插入數據與第一次運行建表的介紹,下面我再介紹刪除與修改的方法,下面的代碼我都加了注釋,自己需要什么方法(刪除,修改,循環數據庫的值)就把注釋去掉就可以了
HSQL比較簡單,大家看一下例子就應該明白了,這里就不講了。
遍歷數據庫的方法有三種,分別是Query,find,iterate,Query和find返回一個List接口,iterate返回一個Iterator,具體方法可以查看這些類得知。

//刪除數據
/*
int a=session.delete("from Hello_Bean where id=1");//假如沒有找到id為1的數據那么返回0,假如找到返回1,這里的Hello_Bean是我們的Hello_Bean類,他跟數據庫表對應,所以我們在這里是直接用Hello_Bean來代碼數據庫表的。
System.out.println(a);
session.flush();
session.close();

*/

//Query方法查詢數據
/*
Hello_Bean my_hibernate = null;
Query q = session.createQuery("from Hello_Bean");
// Query q = session.createQuery("from Hello_Bean where name=?");//這里的?跟JDBC的PreparedStatement方法的差不多,只不過這里的是以0開始,jdbc的是1開始。
// q.setString(0,"my_name");
// q.setFirstResult(0);//這句話的意思是說查詢結果從第幾行開始列出數據
// q.setMaxResults(3);//這句話的意思是取多少條數據,就跟SQL SERVER的TOP方法和MYSQL的LIMIT方法一樣的意思。
// ScrollableResults sc=q.scroll();//得到一個ScrollableResults,可滾動的,假如你的數據庫支持游標自由移動的話可以加上,也就是說可以判定查詢結果有沒有值,或者移動到下一行記錄等等。

// if(!sc.next())
// {
// System.out.println("沒有找到你需要的數據");
// }

session.flush();//假如使用了ScrollableResults的話請把這行注釋掉
session.close();//假如使用了ScrollableResults的話請把這行注釋掉

List l=q.list();//返回一個List接口,用來遍歷結果集

for(int i=0;i<l.size();i++){
my_hibernate = (Hello_Bean) l.get(i);//從List中取得一個my_hibernate對象
System.out.println(my_hibernate.getName());//調用my_hibernate對象的getName方法取得數據庫name字段的值

}

*/

//find方法查詢數據
/*
Hello_Bean my_hibernate = null;
List q = session.find("from Hello_Bean");
session.flush();
session.close();

for(int i=0;i<q.size();i++)
{
my_hibernate = (Hello_Bean) q.get(i);
System.out.println(my_hibernate.getName());
}
*/

//iterate方法查詢數據
/*
Hello_Bean my_hibernate = null;
Iterator q = session.iterate("from Hello_Bean");

while(q.hasNext())
{
my_hibernate = (Hello_Bean) q.next();
System.out.println(my_hibernate.getName());
}

*/

//修改數據
/*
Query qq=session.createQuery("from Hello_Bean");

Hello_Bean my_hibernate=(Hello_Bean)session.load(Hello_Bean.class,new Integer(2));
//這里的new Integer(2)意思是修改表中id為2的那一行數據,必須是一個包裝類的對象,假如使用int的話會出錯。
my_hibernate.setName("geezer");//把id為2的那一行數據的name字段值改為"geezer"
session.flush();
session.close();

*/

}

}

最后運行就可以了。

假如大家有什么不清楚的,可以下載這篇文章的例子看看,運行一下。
下載地址:http://www.phpx.com/happy/attachment.php?s=&postid=599353

下載完以后用JB打開hibernate.jpx就可以了。用之前把hibernate和MYSQL的驅動加進去,方法假如不知道再看看本章開頭部分。


常見錯誤:
Caused by: org.dom4j.DocumentException: Invalid byte 2 of 2-byte UTF-8 sequence. Nested exception: Invalid byte 2 of 2-byte UTF-8 sequence.
假如出現這行錯誤說明你的xml配置文件有不規范的字符,檢查下。

net.sf.hibernate.MappingException: Error reading resource: hibernate/Hello_Bean.hbm.xml


假如出現這行錯誤說明你的hibernate的XML配置文件有錯

net.sf.hibernate.MappingException: Resource: hibernate/Hello_Bean.hbm.xml not found


假如出現這行錯誤說明hibernate的XML配置文件沒有找到,你應該把XML文件放在與你的類文件同個目錄下,本文中是放在hibernateclasseshibernate目錄下,也就是跟Hello_Bean.class類文件一起。

net.sf.hibernate.PropertyNotFoundException: Could not find a setter for property name in class hibernate.Hello_Bean


假如出現這行錯誤說明你的xml文件里設置的字段名name的值與Hello_Bean.java類里的getXXX或setXXX方法不一致。

net.sf.hibernate.HibernateException: JDBC Driver class not found: org.gjt.mm.mysql.Driver
假如出現這行錯誤說明你的MYSQL驅動沒有加進JB庫里或者不在CLASSPATH里。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久99热这里只有精品国产| 国产精品精品一区二区三区午夜版| 欧美性生交xxxxxdddd| 亚洲福利视频二区| 亚洲成人av在线播放| 精品国产欧美一区二区五十路| 午夜精品久久久久久久久久久久| 成人午夜一级二级三级| 国产精品久久久久久影视| 日韩中文字幕av| 亚洲福利视频专区| 亚洲视频欧美视频| 国产欧美日韩免费看aⅴ视频| 91网在线免费观看| 亚洲免费小视频| 精品久久久久久亚洲国产300| 亚洲人成在线观看| 久久久伊人欧美| 国产精品直播网红| 国模叶桐国产精品一区| 欧美三级免费观看| 日韩精品免费在线观看| 欧美激情在线观看| 国产在线视频91| 国产在线观看精品一区二区三区| 亚洲男人天堂古典| 久久精品国产亚洲| 日韩精品中文字| 亚洲国产欧美日韩精品| 亚洲天堂色网站| 久久久在线视频| 久久九九热免费视频| 国产主播欧美精品| 久久精品中文字幕电影| 91精品国产亚洲| 国产精品一区二区在线| 国产精品视频xxxx| 久久人91精品久久久久久不卡| 欧美成人精品在线播放| 欧洲永久精品大片ww免费漫画| 在线播放国产一区中文字幕剧情欧美| 欧美大片va欧美在线播放| 国语对白做受69| 日韩欧美成人网| 68精品久久久久久欧美| 亚洲欧美制服丝袜| 欧美激情视频免费观看| 国产一区私人高清影院| 日韩国产精品一区| www.欧美精品一二三区| 久久综合五月天| 日韩一区二区三区xxxx| 日韩中文字幕网站| 欧美成人激情图片网| 欧美成人精品在线| 一本大道亚洲视频| 欧美日韩免费网站| 亚洲综合视频1区| 在线亚洲欧美视频| 欧美日韩国产丝袜另类| 一区二区在线视频播放| 亚洲美女福利视频网站| 欧美日韩国产综合新一区| 国产丝袜一区二区三区免费视频| 国产精品久久久久久久app| 国产99视频在线观看| 久久成人综合视频| 欧美大学生性色视频| 91精品久久久久久久久久久久久久| 欧美精品成人91久久久久久久| 精品久久国产精品| 成人精品久久一区二区三区| 欧美孕妇孕交黑巨大网站| 日韩福利伦理影院免费| 成人黄色短视频在线观看| 成人黄色av免费在线观看| 久久人人爽亚洲精品天堂| 98精品国产高清在线xxxx天堂| 国产在线精品播放| 国产精品亚洲第一区| 色婷婷亚洲mv天堂mv在影片| 亚洲aⅴ日韩av电影在线观看| 久久精品视频亚洲| 91精品视频网站| 精品亚洲永久免费精品| 久久精品国产成人精品| 欧美性xxxx极品hd满灌| 隔壁老王国产在线精品| 青青在线视频一区二区三区| 国产精品久久久久久av下载红粉| 欧美丰满老妇厨房牲生活| 亚洲精品国产suv| 北条麻妃一区二区在线观看| 国产成人精品一区二区三区| 日韩理论片久久| 在线视频国产日韩| 日韩毛片中文字幕| 国产欧美日韩中文字幕| 欧美精品在线免费播放| 亚洲成色777777女色窝| 日本免费在线精品| 久久夜精品香蕉| 97在线精品国自产拍中文| 国产区亚洲区欧美区| 国产精品激情av电影在线观看| 亚洲欧美日韩成人| 欧美黑人性猛交| 97国产精品久久| 中文字幕国产精品| 国产精品草莓在线免费观看| 亚洲jizzjizz日本少妇| 久久久久久久久久久国产| 亚洲综合第一页| 4k岛国日韩精品**专区| 全亚洲最色的网站在线观看| 亚洲第一在线视频| 欧美人成在线视频| 亚洲伊人第一页| 中文字幕在线精品| 91精品国产91| 一本色道久久88精品综合| 欧美性极品少妇精品网站| 精品电影在线观看| 伦理中文字幕亚洲| 欧美中文字幕第一页| 日韩高清电影免费观看完整版| 在线中文字幕日韩| 成人福利网站在线观看11| 国内精品国产三级国产在线专| 成人深夜直播免费观看| 欧美激情免费视频| 国产精品欧美日韩| 91av在线免费观看视频| 一区二区三区亚洲| 午夜精品三级视频福利| 亚洲国产91色在线| 97超级碰碰人国产在线观看| 久久精品视频亚洲| 日韩免费av在线| 亚洲女同性videos| 久久久在线视频| 91精品视频一区| 疯狂做受xxxx欧美肥白少妇| 精品久久在线播放| 粉嫩老牛aⅴ一区二区三区| 97精品国产91久久久久久| 日韩美女免费线视频| 最近2019好看的中文字幕免费| 国产精品亚洲一区二区三区| 日韩精品中文字幕在线播放| 国产99视频精品免视看7| 久久这里只有精品99| 在线观看欧美成人| 日韩av电影免费观看高清| 91精品视频在线播放| 久久久最新网址| 在线观看精品国产视频| 另类美女黄大片| 久久久综合av| 日韩电影中文字幕av| 久久久999精品| 久久久久久久一区二区三区| 久久久久亚洲精品| 一区二区在线视频|