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

Mybatis應用mysql存儲過程查詢數(shù)據(jù)實例

 更新時間:2017年12月31日 15:10:07   作者:Pionner17  
下面小編就為大家分享一篇Mybatis應用mysql存儲過程查詢數(shù)據(jù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

1.創(chuàng)建mysql存儲過程,這是個復雜查詢加上了判斷,比較復雜

CREATE PROCEDURE searchAllList (
	IN tradingAreaId VARCHAR (50),
	IN categoryName VARCHAR (100),
	IN intelligenceSort TINYINT UNSIGNED,
	IN priceBegin DOUBLE,
	IN priceEnd DOUBLE,
	IN commodityName VARCHAR (200),
	IN flag TINYINT UNSIGNED
)
BEGIN
IF flag = 0 THEN
	SELECT
		B.user_business_id businessId,
		B.shop_name,
		B.total_score,
		B.shop_logo,
		B.average_consume,
		D.category_name,
		B.shop_address
	FROM
		user_business_commodity A
	LEFT JOIN user_business B ON B.user_business_id = A.user_business_id
	LEFT JOIN user_business_category C ON C.business_id = B.user_business_id
	LEFT JOIN service_category D ON D.category_id = C.category_one_id
	WHERE
		1 = 1
	AND
	IF (
		categoryName IS NOT NULL
		AND LENGTH(TRIM(categoryName)) > 0,
		D.category_name = categoryName,
		1 = 1
	)
	AND
	IF (
		priceBegin != 0,
		B.average_consume >= priceBegin,
		1 = 1
	)
	AND
	IF (
		priceEnd != 0,
		B.average_consume <= priceEnd,
		1 = 1
	)
	AND
	IF (
		commodityName IS NOT NULL
		AND LENGTH(TRIM(commodityName)) > 0,
		A. NAME LIKE concat('%', commodityName, '%'),
		1 = 1
	)
	AND B.is_delete = 0
	AND B.shop_setup_state = 1
	AND A.is_delete = 0
	AND C.is_delete = 0
	AND D.is_delete = 0
	GROUP BY
		A.user_business_id
	ORDER BY
		CASE intelligenceSort
	WHEN 1 THEN
		'B.total_order DESC'
	WHEN 2 THEN
		'B.total_score DESC'
	WHEN 3 THEN
		'B.create_time DESC'
	ELSE
		'B.create_time ASC'
	END;

ELSE
	SELECT
		B.user_business_id businessId,
		B.shop_name,
		B.total_score,
		B.shop_logo,
		B.average_consume,
		D.category_name,
		B.shop_address
	FROM
		user_business_commodity A
	LEFT JOIN user_business B ON B.user_business_id = A.user_business_id
	LEFT JOIN user_business_category C ON C.business_id = B.user_business_id
	LEFT JOIN service_category D ON D.category_id = C.category_two_id
	WHERE
		1 = 1
	AND
	IF (
		categoryName IS NOT NULL
		AND LENGTH(TRIM(categoryName)) > 0,
		D.category_name = categoryName,
		1 = 1
	)
	AND
	IF (
		priceBegin != 0,
		B.average_consume >= priceBegin,
		1 = 1
	)
	AND
	IF (
		priceEnd != 0,
		B.average_consume <= priceEnd,
		1 = 1
	)
	AND
	IF (
		commodityName IS NOT NULL
		AND LENGTH(TRIM(commodityName)) > 0,
		A. NAME LIKE concat('%', commodityName, '%'),
		1 = 1
	)
	AND B.is_delete = 0
	AND B.shop_setup_state = 1
	AND A.is_delete = 0
	AND C.is_delete = 0
	AND D.is_delete = 0
	GROUP BY
		A.user_business_id
	ORDER BY
		CASE intelligenceSort
	WHEN 1 THEN
		'B.total_order DESC'
	WHEN 2 THEN
		'B.total_score DESC'
	WHEN 3 THEN
		'B.create_time DESC'
	ELSE
		'B.create_time ASC'
	END;

END IF;
END;

2.查看存儲過程是否創(chuàng)建成功:

show procedure status; 

3.sqlMapper文件:

<select id="searchAllList1" parameterMap="searchAllListMap" statementType="CALLABLE" resultType="com.dongjia168.platform.vo.erp.crm.BusinessShopResp"> 
    CALL searchAllList(#{tradingAreaId},#{categoryName},#{intelligenceSort},#{priceBegin},#{priceEnd},#{commodityName},#{flag}); 
  </select> 
<parameterMap id="searchAllListMap" type="com.dongjia168.platform.vo.erp.crm.BusinessShopReq"> 
    <parameter property="tradingAreaId" jdbcType="VARCHAR" mode="IN"/> 
    <parameter property="categoryName" jdbcType="VARCHAR" mode="IN"/> 
    <parameter property="intelligenceSort" jdbcType="INTEGER" mode="IN"/> 
    <parameter property="priceBegin" jdbcType="DOUBLE" mode="IN"/> 
    <parameter property="priceEnd" jdbcType="DOUBLE" mode="IN"/> 
    <parameter property="commodityName" jdbcType="VARCHAR" mode="IN"/> 
    <parameter property="flag" jdbcType="INTEGER" mode="IN"/> 
  </parameterMap> 

其他和直接調(diào)用sql語句一樣了

以上這篇Mybatis應用mysql存儲過程查詢數(shù)據(jù)實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • springboot通用分支處理超級管理員權(quán)限邏輯

    springboot通用分支處理超級管理員權(quán)限邏輯

    這篇文章主要為大家介紹了springboot通用分支處理超級管理員的權(quán)限邏輯,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • Java http請求封裝工具類代碼實例

    Java http請求封裝工具類代碼實例

    這篇文章主要介紹了Java http請求封裝工具類代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • Spring實戰(zhàn)之獲取其他Bean的屬性值操作示例

    Spring實戰(zhàn)之獲取其他Bean的屬性值操作示例

    這篇文章主要介紹了Spring實戰(zhàn)之獲取其他Bean的屬性值操作,結(jié)合實例形式分析了Spring操作Bean屬性值的相關配置與實現(xiàn)技巧,需要的朋友可以參考下
    2019-12-12
  • Java動態(tài)編譯執(zhí)行代碼示例

    Java動態(tài)編譯執(zhí)行代碼示例

    這篇文章主要介紹了Java動態(tài)編譯執(zhí)行代碼示例,具有一定借鑒價值,需要的朋友可以參考下。
    2017-12-12
  • java中JsonObject與JsonArray轉(zhuǎn)換方法實例

    java中JsonObject與JsonArray轉(zhuǎn)換方法實例

    在項目日常開發(fā)中常常會遇到JSONArray和JSONObject的轉(zhuǎn)換,很多公司剛?cè)肼毜男∶刃聲ㄔ谶@里,下面這篇文章主要給大家介紹了關于java中JsonObject與JsonArray轉(zhuǎn)換方法的相關資料,需要的朋友可以參考下
    2023-04-04
  • java  實現(xiàn)輸出隨機圖片實例代碼

    java 實現(xiàn)輸出隨機圖片實例代碼

    這篇文章主要介紹了java 實現(xiàn)輸出隨機圖片實例代碼的相關資料,需要的朋友可以參考下
    2017-06-06
  • java使用單向鏈表解決數(shù)據(jù)存儲自定義排序問題

    java使用單向鏈表解決數(shù)據(jù)存儲自定義排序問題

    本文主要介紹了java使用單向鏈表解決數(shù)據(jù)存儲自定義排序問題,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • idea中maven本地倉庫jar包打包失敗和無法引用的問題解決

    idea中maven本地倉庫jar包打包失敗和無法引用的問題解決

    本文主要介紹了idea中maven本地倉庫jar包打包失敗和無法引用的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • Java數(shù)組實例練習題整理

    Java數(shù)組實例練習題整理

    在本篇文章中小編給各位分享的是關于Java數(shù)組實例練習題以及相關代碼整理,有需要的朋友們跟著學習下。
    2019-07-07
  • Spring中@Primary注解的作用詳解

    Spring中@Primary注解的作用詳解

    這篇文章主要介紹了Spring中@Primary注解的作用詳解,@Primary 注解是Spring框架中的一個注解,用于標識一個Bean作為默認的實現(xiàn)類,當存在多個實現(xiàn)類時,通過使用@Primary注解,可以指定其中一個作為默認的實現(xiàn)類,以便在注入時自動選擇該實現(xiàn)類,需要的朋友可以參考下
    2023-10-10

最新評論