当前位置: 首页 > 编程笔记 >

Mybatis应用mysql存储过程查询数据实例

乌翔
2023-03-14
本文向大家介绍Mybatis应用mysql存储过程查询数据实例,包括了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存储过程查询数据实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。

 类似资料:
  • 问题内容: 存储过程的执行情况如何?是否值得使用它们而不是在PHP / MySQL调用中实现复杂的查询? 问题答案: 存储过程将为您带来一点性能提升,但是大多数情况下,它们是用于执行用简单查询很难或不可能完成的任务。存储过程非常适合简化许多不同类型的客户端对数据的访问。数据库管理员之所以喜欢它们,是因为他们控制数据库的使用方式,而不是将这些细节留给开发人员。 寻找索引和适当的表设计以获得更好的性能

  • 问题内容: 我在存储过程中创建一个动态查询。我的存储过程如下: 当我尝试通过以下调用运行它时: 我收到以下错误消息: 错误代码:1054。“ where子句”中的未知列“ SPA” 我在没有where条件的情况下进行了测试,并且工作正常,但是在where条件不起作用的情况下,我尝试使用@和变量名一起使用,但仍然无法正常工作。 谢谢你的帮助。 问题答案: 您错过了条款中的引号。 尝试这样: 说明 :

  • 本文向大家介绍在MySQL存储过程中实现动态SQL查询?,包括了在MySQL存储过程中实现动态SQL查询?的使用技巧和注意事项,需要的朋友参考一下 对于存储过程中的动态SQL查询,请使用PREPARE STATEMENT的概念。让我们首先创建一个表- 使用插入命令在表中插入一些记录- 使用select语句显示表中的所有记录- 这将产生以下输出- 以下是创建存储过程并实现动态SQL的查询- 调用存储

  • 主要内容:查看存储过程的状态,查看存储过程的定义创建好存储过程后,用户可以通过 SHOW ATATUS 语句来查看存储过程的状态,也可以通过 SHOW CREATE 语句来查看存储过程的定义。本节主要讲解查看存储过程的状态和定义的方法。 查看存储过程的状态 MySQL 中可以通过 SHOW STATUS 语句查看存储过程的状态,其基本语法形式如下: SHOW PROCEDURE STATUS LIKE 存储过程名; 用来匹配存储过程的名称,LI

  • 我们前面所学习的 MySQL 语句都是针对一个表或几个表的单条 SQL 语句,但是在数据库的实际操作中,经常会有需要多条 SQL 语句处理多个表才能完成的操作。 例如,为了确认学生能否毕业,需要同时查询学生档案表、成绩表和综合表,此时就需要使用多条 SQL 语句来针对这几个数据表完成处理要求。 存储过程是一组为了完成特定功能的 SQL 语句集合。使用存储过程的目的是将常用或复杂的工作预先用 SQL

  • 问题内容: 我有一个应用程序,每小时执行约20000次DATA-OPERATIONS DATA- OPERATION总共具有30个参数(用于所有10个查询)。有些是文本,有些是数字。某些Text参数最长为10000个字符。 每个DATA-OPERATION都执行以下操作: 单个DATA-OPERATION,可在数据库中插入/更新多个表(约10个)。 对于每一次DATA-OPERATION,我都会建