欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SSH框架網(wǎng)上商城項目第5戰(zhàn)之商品類別級聯(lián)查詢和分頁功能

 更新時間:2016年05月26日 17:05:55   作者:eson_15  
SSH框架網(wǎng)上商城項目第5戰(zhàn)之商品類別級聯(lián)查詢和分頁功能,寫一下CategoryServiceImpl實現(xiàn)類,完成數(shù)據(jù)庫的級聯(lián)查詢,感興趣的小伙伴們可以參考一下

上文我們完成了EasyUI菜單的實現(xiàn),點擊這里查看,這一節(jié)我們主要來寫一下CategoryServiceImpl實現(xiàn)類,完成數(shù)據(jù)庫的級聯(lián)查詢。一般項目從后往前做,先做service(我們沒有抽取Dao,最后再抽?。?,做完了再做上面層。
在寫之前,先看一下數(shù)據(jù)庫中的表的情況:

drop database if exists shop; 
/*創(chuàng)建數(shù)據(jù)庫,并設(shè)置編碼*/ 
create database shop default character set utf8; 
 
use shop; 
/*刪除管理員表*/ 
drop table if exists account; 
/*刪除商品類別表*/ 
drop table if exists category; 
 
/*============================*/ 
/*   Table:管理員表結(jié)構(gòu)            */ 
/*============================*/ 
create table account 
( 
  /* 管理員編號,自動增長 */ 
  id int primary key not null auto_increment, 
  /* 管理員登錄名 */ 
  login varchar(20), 
  /* 管理員姓名 */ 
  name varchar(20), 
  /* 管理員密碼 */ 
  pass varchar(20) 
); 
 
/*============================*/ 
/*   Table:商品類別表結(jié)構(gòu)           */ 
/*============================*/ 
create table category 
( 
  /* 類別編號,自動增長 */ 
  id int primary key not null auto_increment, 
  /* 類別名稱 */ 
  type varchar(20), 
  /* 類別是否為熱點類別,熱點類別才有可能顯示在首頁*/ 
  hot bool default false, 
  /* 外鍵,此類別由哪位管理員管理 */ 
  account_id int, 
  constraint aid_FK foreign key(account_id) references account(id) 
); 

主要有兩張表,商品類別表和管理員表,并且商品類別表中提供了一個外鍵關(guān)聯(lián)管理員表。也就是商品和管理員是多對一的關(guān)系?,F(xiàn)在我們開始編寫查詢商品的類別信息,需要級聯(lián)管理員。
1. 實現(xiàn)級聯(lián)查詢方法
首先在CategoryService接口中定義該方法:

public interface CategoryService extends BaseService<Category> { 
  //查詢類別信息,級聯(lián)管理員 
  public List<Category> queryJoinAccount(String type); //使用類別的名稱查詢 
} 

然后我們在CategoryService的實現(xiàn)類CategoryServiceImpl中實現(xiàn)這個方法:

@Service("categoryService") 
public class CategoryServiceImpl extends BaseServiceImpl<Category> implements CategoryService { 
 
  @Override 
  public List<Category> queryJoinAccount(String type) { 
    String hql = "from Category c where c.type like :type"; 
    return getSession().createQuery(hql) 
        .setString("type", "%" + type + "%").list(); 
  } 
} 

在兩個Model中我們配一下關(guān)聯(lián)注解:

//Category類中 
@ManyToOne(fetch = FetchType.EAGER) 
@JoinColumn(name = "account_id") 
public Account getAccount() { 
  return this.account; 
} 
//Account類中 
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "account") 
public Set<Category> getCategories() { 
  return this.categories; 
} 

然后我們在測試類中測試一下:

@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration(locations="classpath:beans.xml") 
public class CategoryServiceImplTest { 
 
  @Resource 
  private CategoryService categoryService; 
   
  @Test 
   public void testQueryJoinAccount() { 
    for(Category c : categoryService.queryJoinAccount("")) { 
       System.out.println(c); 
       System.out.println(c.getAccount()); 
    } 
  } 
} 

2. 級聯(lián)查詢存在的問題
我們看一下控制臺的輸出可以看出,它發(fā)了不止一條SQL語句,但是我們明明只查詢了一次,為什么會發(fā)這么多語句呢?這就是常見的1+N問題。所謂的1+N問題,就是首先發(fā)出一條語句查詢當前對象,然后發(fā)出N條語句查詢關(guān)聯(lián)對象,因此效率變得很低。這里就兩個對象,如果有更多的對象,那效率就會大打折扣了,我們該如何解決這個問題呢?
可能大家會想到將fetch設(shè)置生FetchType.LAZY就不會發(fā)多條語句了,但是這肯定不行,因為設(shè)置成LAZY后,我們就拿不到Account對象了,比較好的解決方法是我們自己寫hql語句,使用join fetch。具體看修改后的CategoryServiceImpl實現(xiàn)類:

@Service("categoryService") 
public class CategoryServiceImpl extends BaseServiceImpl<Category> implements CategoryService { 
 
  @Override 
  public List<Category> queryJoinAccount(String type) { 
    String hql = "from Category c left join fetch c.account where c.type like :type"; 
    return getSession().createQuery(hql) 
        .setString("type", "%" + type + "%").list(); 
  } 
} 

left join表示關(guān)聯(lián)Account一起查詢,fetch表示將Account對象加到Category中去,這樣就只會發(fā)一條SQL語句了,并且返回的Category中也包含了Account對象了。
3. 完成分頁功能
Hibernate中的分頁很簡單,只需要調(diào)用兩個方法setFirstResult和setMaxResults即可:我們修改一下CategoryService接口和它的實現(xiàn)類CategoryServiceImpl:

//CategoryService 
public interface CategoryService extends BaseService<Category> { 
  //查詢類別信息,級聯(lián)管理員 
  public List<Category> queryJoinAccount(String type, int page, int size); //并實現(xiàn)分頁 
} 
 
//CategoryServiceImpl 
@Service("categoryService") 
public class CategoryServiceImpl extends BaseServiceImpl<Category> implements CategoryService { 
 
  @Override 
  public List<Category> queryJoinAccount(String type, int page, int size) { 
    String hql = "from Category c left join fetch c.account where c.type like :type"; 
    return getSession().createQuery(hql) 
        .setString("type", "%" + type + "%") 
        .setFirstResult((page-1) * size) //從第幾個開始顯示 
        .setMaxResults(size) //顯示幾個 
        .list(); 
  } 
} 

我們在測試類中測試一下:

@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration(locations="classpath:beans.xml") 
public class CategoryServiceImplTest { 
 
  @Resource 
  private CategoryService categoryService; 
 
  @Test 
  public void testQueryJoinAccount() { 
    for(Category c : categoryService.queryJoinAccount("",1,2)) { //顯示第一頁,每頁2條數(shù)據(jù) 
      System.out.println(c + "," + c.getAccount()); 
    } 
  } 
} 

為此,我們寫完了Service的方法了,完成了對商品類別的級聯(lián)查詢和分頁功能。
(注:到最后我會提供整個項目的源碼下載!歡迎大家收藏或分享)
原文地址:http://blog.csdn.net/eson_15/article/details/51320212
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot多模塊項目框架搭建過程解析

    SpringBoot多模塊項目框架搭建過程解析

    這篇文章主要介紹了SpringBoot多模塊項目框架搭建過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-01-01
  • Java集合之LinkedHashSet類詳解

    Java集合之LinkedHashSet類詳解

    這篇文章主要介紹了Java集合之LinkedHashSet類詳解,LinkedHashSet 是 Java 中的一個集合類,它是 HashSet 的子類,并實現(xiàn)了 Set 接口,與 HashSet 不同的是,LinkedHashSet 保留了元素插入的順序,并且具有 HashSet 的快速查找特性,需要的朋友可以參考下
    2023-09-09
  • springboot+maven快速構(gòu)建項目的示例代碼

    springboot+maven快速構(gòu)建項目的示例代碼

    本篇文章主要介紹了springboot+maven快速構(gòu)建項目的示例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Java用freemarker導出word實用示例

    Java用freemarker導出word實用示例

    本篇文章主要介紹了Java用freemarker導出word實用示例,使用freemarker的模板來實現(xiàn)功能,有需要的可以了解一下。
    2016-11-11
  • Java中for循環(huán)遍歷刪除操作方法

    Java中for循環(huán)遍歷刪除操作方法

    在Java中,有些場景需要遍歷集合中的元素,然后根據(jù)條件進行刪除元素的操作,本文結(jié)合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • 使用XSD校驗Mybatis的SqlMapper配置文件的方法(1)

    使用XSD校驗Mybatis的SqlMapper配置文件的方法(1)

    這篇文章以前面對SqlSessionFactoryBean的重構(gòu)為基礎(chǔ),簡單的介紹了相關(guān)操作知識,然后在給大家分享使用XSD校驗Mybatis的SqlMapper配置文件的方法,感興趣的朋友參考下吧
    2016-11-11
  • Quarkus集成apollo配置中心

    Quarkus集成apollo配置中心

    這篇文章主要介紹了Quarkus集成apollo配置中心,文中詳細的講解了Quarkus的config構(gòu)成,以及apollo集成實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2022-02-02
  • Spring Boot中擴展XML請求與響應(yīng)的支持詳解

    Spring Boot中擴展XML請求與響應(yīng)的支持詳解

    這篇文章主要給大家介紹了關(guān)于Spring Boot中擴展XML請求與響應(yīng)的支持的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-09-09
  • Java批量導出word壓縮后的zip文件案例

    Java批量導出word壓縮后的zip文件案例

    這篇文章主要介紹了Java批量導出word壓縮后的zip文件案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • Java詳解ScriptEngine接口動態(tài)執(zhí)行JS腳本

    Java詳解ScriptEngine接口動態(tài)執(zhí)行JS腳本

    ScriptEngine是基本接口,其方法必須在本規(guī)范的每個實現(xiàn)中完全起作用。這些方法提供基本腳本功能。 寫入這個簡單接口的應(yīng)用程序可以在每個實現(xiàn)中進行最少的修改。 它包括執(zhí)行腳本的方法,以及設(shè)置和獲取值的方法
    2022-08-08

最新評論