一、find(String queryString);
示例:this.getHibernateTemplate().find("from bean.User");
返回所有User對象
二、find(String queryString , Object value);
示例:this.getHibernateTemplate().find("from bean.User u where u.name=?", "test");
或模糊查詢:this.getHibernateTemplate().find("from bean.User u where u.name like ?", "%test%");
返回name屬性值為test的對象(模糊查詢,返回name屬性值包含test的對象)
三、find(String queryString, Object[] values);
示例:String hql= "from bean.User u where u.name=? and u.password=?"
this.getHibernateTemplate().find(hql, new String[]{"test", "123"});
返回用戶名為test並且密碼為123的所有User對象
---------------------------------
四、findByExample(Object exampleEntity)
示例:
User u=new User();
u.setPassword("123");//必須 符合的條件但是這兩個條件時並列的(象當於sql中的and)
u.setName("bb");
list=this.getHibernateTemplate().findByExample(u,start,max);
返回:用戶名為bb密碼為123的對象
五、findByExample(Object exampleEntity, int firstResult, int maxResults)
示例:
User u=new User();
u.setPassword("123");//必須 符合的條件但是這兩個條件時並列的(象當於sql中的and)
u.setName("bb");
list=this.getHibernateTemplate().findByExample(u,start,max);
返回:滿足用戶名為bb密碼為123,自start起共max個User對象。(對象從0開始計數)
---------------------------------------------------
六、findByNamedParam(String queryString , String paramName , Object value)
使用以下語句查詢:
String queryString = "select count(*) from bean.User u where u.name=:myName";
String paramName= "myName";
String value= "xiyue";
this.getHibernateTemplate().findByNamedParam(queryString, paramName, value);
System.out.println(list.get(0));
返回name為xiyue的User對象的條數
七、findByNamedParam(String queryString , String[] paramName , Object[] value)
示例:
String queryString = "select count(*) from bean.User u where u.name=:myName and u.password=:myPassword";
String[] paramName= new String[]{"myName", "myPassword"};
String[] value= new String[]{"xiyue", "123"};
this.getHibernateTemplate().findByNamedParam(queryString, paramName, value);
返回用戶名為xiyue密碼為123的User對象
八、findByNamedQuery(String queryName)
示例:
1、首先需要在User.hbm.xml中定義命名查詢
<hibernate-mapping>
<class>......</class>
<query name="queryAllUser"><!--此查詢被調用的名字-->
<![CDATA[
from bean.User
]]>
</query>
</hibernate-mapping>
2、如下使用查詢:
this.getHibernateTemplate().findByNamedQuery("queryAllUser");
九、findByNamedQuery(String queryName, Object value)
示例:
1、首先需要在User.hbm.xml中定義命名查詢
<hibernate-mapping>
<class>......</class>
<query name="queryByName"><!--此查詢被調用的名字-->
<![CDATA[
from bean.User u where u.name = ?
]]>
</query>
</hibernate-mapping>
2、如下使用查詢:
this.getHibernateTemplate().findByNamedQuery("queryByName", "test");
十、findByNamedQuery(String queryName, Object[] value)
示例:
1、首先需要在User.hbm.xml中定義命名查詢
<hibernate-mapping>
<class>......</class>
<query name="queryByNameAndPassword"><!--此查詢被調用的名字-->
<![CDATA[
from bean.User u where u.name =? and u.password =?
]]>
</query>
</hibernate-mapping>
2、如下使用查詢:
String[] values= new String[]{"test", "123"};
this.getHibernateTemplate().findByNamedQuery("queryByNameAndPassword" , values);
十一、findByNamedQueryAndNamedParam(String queryName, String paramName, Object value)
示例:
1、首先需要在User.hbm.xml中定義命名查詢
<hibernate-mapping>
<class>......</class>
<query name="queryByName"><!--此查詢被調用的名字-->
<![CDATA[
from bean.User u where u.name =:myName
]]>
</query>
</hibernate-mapping>
2、如下使用查詢:
this.getHibernateTemplate().findByNamedQuery("queryByName" , "myName", "test");
十二、findByNamedQueryAndNamedParam(String queryName, String[] paramName, Object[] value)
示例:
1、首先需要在User.hbm.xml中定義命名查詢
<hibernate-mapping>
<class>......</class>
<query name="queryByNameAndPassword"><!--此查詢被調用的名字-->
<![CDATA[
from bean.User u where u.name =:myName and u.password=:myPassword
]]>
</query>
</hibernate-mapping>
2、如下使用查詢:
String[] names= new String[]{"myName", "myPassword"};
String[] values= new String[]{"test", "123"};
this.getHibernateTemplate().findByNamedQuery("queryByNameAndPassword" , names, values);
十三、findByValueBean(String queryString , Object value);
示例:
1、定義一個ValueBean,屬性名必須和HSQL語句中的:后面的變量名同名,此處必須至少有兩個屬性,分別為myName和myPassword,使用setter方法設置屬性值后
ValueBean valueBean= new ValueBean();
valueBean.setMyName("test");
valueBean.setMyPasswrod("123");
2、
String queryString= "from bean.User u where u.name=:myName and u.password=:myPassword";
this.getHibernateTemplate().findByValueBean(queryString , valueBean);
十四、findByNamedQueryAndValueBean(String queryName , Object value);
示例:
1、首先需要在User.hbm.xml中定義命名查詢
<hibernate-mapping>
<class>......</class>
<query name="queryByNameAndPassword"><!--此查詢被調用的名字-->
<![CDATA[
from bean.User u where u.name =:myName and u.password=:myPassword
]]>
</query>
</hibernate-mapping>
2、定義一個ValueBean,屬性名必須和User.hbm.xml命名查詢語句中的:后面的變量名同名,此處必須至少有兩個屬性,分別為myName和myPassword,使用setter方法設置屬性值后
ValueBean valueBean= new ValueBean();
valueBean.setMyName("test");
valueBean.setMyPasswrod("123");
3、
String queryString= "from bean.User u where u.name=:myName and u.password=:myPassword";
this.getHibernateTemplate().findByNamedQueryAndValueBean("queryByNameAndPassword", valueBean);
struts2的s:iterator 可以遍歷 數據棧里面的任何數組,集合等等 以下幾個簡單的demo:
s:iterator 標簽有3個屬性:
value:被迭代的集合
id :指定集合里面的元素的id
status 迭代元素的索引
1:jsp頁面定義元素寫法 數組或list
<s:iterator value="{'1','2','3','4','5'}" id='number'>
<s:property value='number'/>A
< /s:iterator>
打印結果為: 1A2A3A4A5A
2:索引的用法
如果指定了status,每次的迭代數據都有IteratorStatus的實例,它有以下幾個方法
int getCount()返回當前迭代了幾個元素
int getIndex()返回當前元素索引
boolean isEven()當然的索引是否偶數
boolean isFirst()當前是否第一個元素
boolean isLast()
boolean isOdd()當前元素索引是否奇數
< s:iterator value="{'a','b','c'}" id='char' status='st'>
<s:if test="#st.Even">
現在的索引是奇數為:<s:property value='#st.index'/>
</s:if>
當前元素值:<s:property value='char'/>
< /s:iterator>
3:遍歷map
value可以直接定義為:
value="#{"1":"a","2":"b"}"
每個元素以都好隔開。元素之間的key和value 冒號隔開
value也可以是數據棧里面的java.util.Map對象
遍歷寫法如下:
< s:iterator value="map" id="id" status="st">
key : <s:property value='key'/>
value:<s:property vlaue='value'/>
< /s:iterator>
當然key 和value 都可以使java 的 Object
3:遍歷數據棧.簡單的List類,
List<Attr>
class Attr{String attrName;String getAttrName(){return "123";}}
< s:iterator value="label" id="id">
<s:property value="#id.attrName" />
< /s:iterator>
當然value 還可以寫成 value="%{label}" label可以有.操作
label的屬性List 可以寫成value="%{label.list}" 相當於:getLabel().getList();
4:遍歷2個list;
List<AttrName> attrN {color,size,style}
List<AttrValue> attrV {red,20,gay}
這2個list的元素是一一對應的,一個attrN對應一個attrV
< s:iterator value="%{attrN }" id="id" status="status">
index is : <s:property value='status.index'/>
attrName is : <s:property value='id'/> or <s:property value='%{id}'/>
attrName is : <s:property value='%{attrV[#status.index]}'/>
< /s:iterator>
hibernate插入數據主鍵自增
oracle認證考試
在hibernate中實現oracle的主鍵自增策略
在很多情況下,我們使用Hibernate在已經建立好數據庫的基礎上。在oracle中,如果已經建立好的數據庫中使用了sequence ,則可以按照下面的步驟把它引入到Hibernate中:
1、在oracle 首先創建sequence
create sequence seq_id
minvalue 1
start with 1
increment by 1
cache 20;
2.在你的hbm.xml中的配置
<id column="ID0000" name="id" type="integer">
<generator class="sequence">
<param name="sequence">seq_id</param>
</generator>
</id>
這樣再插入數據的時候,Hibernate回自動生成如下語句:
hibernate : select seq_id.nextval from dual
hibernate : insert into YXJK.T_YXJK_WHRYTXL (XM0000, ZW0000, LXDH00, SJHM00, DZYJ00,
IP0000, ID0000) values (?, ?, ?, ?, ?, ?, ?)
自動生成下一個序列值,然后將對象插入表中。
在使用的時候需要注意,Hibernate對於sequence的主鍵的要求是一定要是shor,long,或者integer
根據hibernate的文檔,有兩種方式實現實體對象的主鍵自動增長。
第一種:設置ID的增長策略是sequence,同時指定sequence的名字,最好每個表建一個sequence,此種做法就如同MS-SQL,MY-SQL中的自動增長一樣,不需要創建觸發器,具體的oracle數據庫腳本及hibernate配置文件如下:
[1]oracle數據表的創建腳本:
Java代碼
1. CREATE TABLE DEPARTMENT (
2. ID NUMBER(19,0) DEFAULT '0' NOT NULL,
3. NAME VARCHAR2(255) NOT NULL,
4. DESCRIPTION CLOB
5. );
6. ALTER TABLE DEPARTMENT ADD CONSTRAINT PRIMARY_0 PRIMARY KEY(ID) ENABLE;
7. ALTER TABLE DEPARTMENT ADD CONSTRAINT UK_DEPARTMENT_1 UNIQUE (NAME);
8.
9. CREATE SEQUENCE DEPARTMENT_ID_SEQ MINVALUE 10000 MAXVALUE 999999999999999999999999 INCREMENT BY 1 NOCYCLE;
復制代碼
創建DEPARTMENT表,並為DEPARTMENT表創建一個單獨的SEQUENCE,名字為SEQUENCE_ID_SEQ,並不需要創建觸發器。
[2]hibernate映射文件的配置:
Java代碼
# <?xml version="1.0"?>
# <!DOCTYPE hibernate-mapping PUBLIC
# "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
# "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
# <hibernate-mapping package="com.liyanframework.demo.domain">
# <class name="Department" table="DEPARTMENT">
# <id name="id" column="ID">
# <generator class="sequence">
# <param name="sequence">DEPARTMENT_ID_SEQ</param>
# </generator>
# </id>
# <property name="name" column="NAME" type="string" />
# <property name="description" column="DESCRIPTION" type="text" />
# </class>
# </hibernate-mapping>
復制代碼
在hibernate映射文件中,對ID的生成策略選擇sequence,指定sequence的名字DEPARTMENT_ID_SEQ就可以了,當你保存新對象的時候,hibernate會自動取得DEPARTMENT_ID_SEQ.NEXTVAL作為新對象的ID保存到數據庫,所以不需要再使用觸發器再來生成新記錄的ID。
第二種:設置ID的增長策略是native,但是需要創建一個名字為 hibernate_sequence(這個名字好像是hibernate默認的sequence名字,不創建會出錯的)的全局使用的sequence,然后再對每一個表的ID生成的時候,使用觸發器,取得 hibernate_sequence.CURRVAL作為新記錄的ID,具體的oracle數據庫腳本及hibernate配置文件如下:
[1]oracle數據表的創建腳本:
Java代碼
# CREATE TABLE STAFF (
# ID NUMBER(19,0) DEFAULT '0' NOT NULL,
# NAME VARCHAR2(255) NOT NULL,
# AGE NUMBER(3,0) NOT NULL,
# BIRTHDAY DATE NOT NULL,
# SALARY NUMBER(10,2) NOT NULL,
# LEVELNESS FLOAT NOT NULL,
# CREATETIME TIMESTAMP NOT NULL,
# ENABLE CHAR(2) DEFAULT 'Y' NOT NULL,
# STATUS VARCHAR2(64) NOT NULL,
# DEPARTMENT_ID NUMBER(19,0)
# );
# ALTER TABLE STAFF ADD CONSTRAINT PRIMARY_1 PRIMARY KEY(ID) ENABLE;
# ALTER TABLE STAFF ADD CONSTRAINT STAFF_IBFK_0 FOREIGN KEY(DEPARTMENT_ID) REFERENCES DEPARTMENT(ID) ENABLE;
# ALTER TABLE STAFF ADD CONSTRAINT UK_STAFF_1 UNIQUE (NAME);
# CREATE INDEX IDX_STAFF_STATUS ON STAFF(STATUS);
#
# CREATE SEQUENCE HIBERNATE_SEQUENCE MINVALUE 90000 MAXVALUE 999999999999999999999999 INCREMENT BY 1 NOCYCLE;
#
# CREATE OR REPLACE TRIGGER STAFF_ID_TRG BEFORE INSERT ON STAFF
# FOR EACH ROW
# BEGIN
# IF INSERTING AND :NEW.ID IS NULL THEN
# SELECT HIBERNATE_SEQUENCE.CURRVAL INTO :NEW.ID FROM DUAL;
# END IF;
# END;
復制代碼
創建STAFF表,但是並沒有為STAFF創建相應的主鍵sequence,而是創建了一個名字為HIBERNATE_SEQUENCE的 sequence,然后創建一個觸發器STAFF_ID_TRG,當執行INSERT操作時,hibernate會先執行一次 HIBERNATE_SEQUENCE.NEXTVAL,所以在觸發器中只需要取得HIBERNATE_SEQUENCE.CURRVAL作為新記錄的 ID。
[2]hibernate映射文件的配置:
Java代碼
# <?xml version="1.0"?>
# <!DOCTYPE hibernate-mapping PUBLIC
# "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
# "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
# <hibernate-mapping package="com.liyanframework.demo.domain">
# <class name="Staff" table="STAFF">
# <id name="id" column="ID">
# <generator class="native" />
# </id>
# <property name="name" column="NAME" type="string" />
# <property name="age" column="AGE" type="integer" />
# <property name="birthday" column="BIRTHDAY" type="date" />
# <property name="salary" column="SALARY" type="big_decimal" />
# <property name="level" column="LEVELNESS" type="float" />
# <property name="createTime" column="CREATETIME" type="timestamp" />
# <property name="enable" column="ENABLE" type="character" />
# <property name="status" column="STATUS" type="string" />
# <many-to-one name="department" column="DEPARTMENT_ID" class="Department" />
# </class>
# </hibernate-mapping>
復制代碼
在hibernate映射文件中,對ID的生成策略選擇native,hibernate會根據你數據庫的觸發器來生成新記錄的ID。
比較兩種做法,第二種做法也就是hibernate在代碼中,實現了oracle中的觸發器功能。對於不同的情況,選擇不懂的做法。如果新的系統,新建的 oracle數據庫,推薦使用第一種做法,簡單,容易移植到其他支持自動增長的數據庫;如果是老的系統,需要把其他數據庫轉換為oracle 的,那就要用第二種了,使用native的方式,可以不改動配置文件,兼容oracle和MySQL之類帶有自動增長的數據庫。