91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

Mybatis應用mysql存儲過程查詢數據的示例分析

發布時間:2021-07-22 15:22:10 來源:億速云 閱讀:195 作者:小新 欄目:編程語言

小編給大家分享一下Mybatis應用mysql存儲過程查詢數據的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1.創建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.查看存儲過程是否創建成功:

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>

其他和直接調用sql語句一樣了

以上是“Mybatis應用mysql存儲過程查詢數據的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

AI

永川市| 鞍山市| 正安县| 新绛县| 鸡西市| 杨浦区| 新源县| 龙里县| 射阳县| 安泽县| 汕头市| 吉水县| 甘泉县| 遂昌县| 剑川县| 余干县| 墨脱县| 石楼县| 蓬莱市| 宝兴县| 清水河县| 临邑县| 日喀则市| 宣武区| 汶上县| 黎城县| 海林市| 敖汉旗| 荃湾区| 永善县| 汕头市| 仁怀市| 峡江县| 房产| 丰都县| 夏邑县| 延吉市| 德兴市| 额敏县| 金乡县| 迁西县|