存储过程加入动态sql

2024-09-02 04:48

本文主要是介绍存储过程加入动态sql,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.创建不带参数的存储过程

drop PROCEDURE if exists my_procedure; 

create PROCEDURE my_procedure() 
BEGIN
DECLARE my_sql VARCHAR(2000);
  set my_sql='SELECT order_info.* FROM order_info WHERE 1 = 1 '; 
 SET @sql1=my_sql;
 PREPARE stmt1 FROM @sql1;
 EXECUTE stmt1;
 DEALLOCATE PREPARE stmt1 ;
end;

CALL my_procedure();


2.创建带参数的存储过程


drop PROCEDURE if exists my_procedure; 


create PROCEDURE my_procedure(IN marketName VARCHAR(100)) 
BEGIN
DECLARE my_sql VARCHAR(2000);
  set my_sql='SELECT order_info.* FROM order_info WHERE 1 = 1 '; 
 IF marketName IS NOT NULL THEN
SET my_sql=CONCAT(my_sql,'AND order_info.market_name LIKE "%',marketName,'%" ');
 END IF;
 SET @sql1=my_sql;
 PREPARE stmt1 FROM @sql1;
 EXECUTE stmt1;
 DEALLOCATE PREPARE stmt1 ;
end;

CALL my_procedure('上海');


3.创建带多参数的单表存储过程

create PROCEDURE my_procedure(IN marketName VARCHAR(100),IN brandName VARCHAR(100),IN seriesName VARCHAR(100),
IN beginDate VARCHAR(100),IN endDate VARCHAR(100),IN startIndex INT(6),IN endIndex INT(6)) 
BEGIN
DECLARE my_sql VARCHAR(2000);
  set my_sql='SELECT order_info.* FROM order_info WHERE 1 = 1 '; 

IF (marketName <> NULL OR marketName <>'') THEN
SET my_sql=CONCAT(my_sql,'AND order_info.market_name LIKE "%',marketName,'%" ');
END IF;

IF (brandName <> NULL OR brandName <>'') THEN
SET my_sql=CONCAT(my_sql,'AND order_info.brand_name LIKE "%',brandName,'%" ');
END IF;

IF (seriesName <> NULL OR seriesName <>'') THEN
SET my_sql=CONCAT(my_sql,'AND order_info.series_name LIKE "%',seriesName,'%" ');
END IF;

IF ((beginDate <> NULL OR beginDate <>'') AND (endDate <> NULL OR endDate <>'')) THEN
SET my_sql=CONCAT(my_sql,'and order_info.order_time between ',"'",beginDate,"'",' and ',"'",endDate,"'");
END IF;

SET my_sql=CONCAT(my_sql,' group by order_info.id order by order_info.market_no,order_info.order_sn ',' LIMIT ',startIndex,',',endIndex);

 SET @sql1=my_sql;
 PREPARE stmt1 FROM @sql1;
 EXECUTE stmt1;
 DEALLOCATE PREPARE stmt1;
end;

CALL my_procedure('上海','',NULL,'2015-06-14','2015-07-11',20,80);


4.创建带多参数的多表存储过程(本例为两表)

create PROCEDURE my_procedure(IN pdtType VARCHAR(100),IN pdtCode VARCHAR(100),IN pdtName VARCHAR(100),
IN marketName VARCHAR(100),IN brandName VARCHAR(100),IN seriesName VARCHAR(100),
IN beginDate VARCHAR(100),IN endDate VARCHAR(100),IN startIndex INT(6),IN endIndex INT(6)) 
BEGIN
DECLARE my_sql VARCHAR(2000);
  set my_sql='SELECT order_info.* FROM order_info '; 

IF ((pdtType <> NULL OR pdtType <>'') OR (pdtCode <> NULL OR pdtCode <>'') OR (pdtName <> NULL OR pdtName <>'')) THEN
SET my_sql=CONCAT(my_sql,'inner join order_item oi on oi.market_no = order_info.market_no and oi.order_sn =order_info.order_sn ');

IF (pdtType <> NULL OR pdtType <>'') THEN
SET my_sql=CONCAT(my_sql,'and oi.pdt_type LIKE "%',pdtType,'%" ');
END IF;

IF (pdtCode <> NULL OR pdtCode <>'') THEN
SET my_sql=CONCAT(my_sql,'and oi.pdt_code =',pdtCode);
END IF;

IF (pdtName <> NULL OR pdtName <>'') THEN
SET my_sql=CONCAT(my_sql,'and oi.pdt_name LIKE "%',pdtName,'%" ');
END IF;

END IF;

SET my_sql=CONCAT(my_sql,' WHERE 1 = 1 ');


IF (marketName <> NULL OR marketName <>'') THEN
SET my_sql=CONCAT(my_sql,'AND order_info.market_name LIKE "%',marketName,'%" ');
END IF;

IF (brandName <> NULL OR brandName <>'') THEN
SET my_sql=CONCAT(my_sql,'AND order_info.brand_name LIKE "%',brandName,'%" ');
END IF;

IF (seriesName <> NULL OR seriesName <>'') THEN
SET my_sql=CONCAT(my_sql,'AND order_info.series_name LIKE "%',seriesName,'%" ');
END IF;

IF ((beginDate <> NULL OR beginDate <>'') AND (endDate <> NULL OR endDate <>'')) THEN
SET my_sql=CONCAT(my_sql,'and order_info.order_time between ',"'",beginDate,"'",' and ',"'",endDate,"'");
END IF;

SET my_sql=CONCAT(my_sql,' group by order_info.id order by order_info.market_no,order_info.order_sn ',' LIMIT ',startIndex,',',endIndex);

 SET @sql1=my_sql;
 PREPARE stmt1 FROM @sql1;
 EXECUTE stmt1;
 DEALLOCATE PREPARE stmt1;
end;

CALL my_procedure('GP','015130844',NULL,'','',NULL,'2015-06-14','2015-07-11',0,80);


5.创建参数为DECIMAL类型的存储过程

create PROCEDURE my_procedure(IN minAmount DECIMAL(20,6),IN maxAmount DECIMAL(20,6)) 
BEGIN
DECLARE my_sql VARCHAR(2000);
  set my_sql='SELECT order_info.* FROM order_info WHERE 1 = 1 '; 
IF (minAmount IS NOT NULL) THEN
SET my_sql=CONCAT(my_sql,'AND order_info.order_amount>=',minAmount);
END IF;

IF (maxAmount IS NOT NULL) THEN
SET my_sql=CONCAT(my_sql,' AND order_info.order_amount<=',maxAmount);
END IF;

SET my_sql=CONCAT(my_sql,' group by order_info.id order by order_info.market_no,order_info.order_sn ');

 SET @sql1=my_sql;
 PREPARE stmt1 FROM @sql1;
 EXECUTE stmt1;
 DEALLOCATE PREPARE stmt1;
end;

CALL my_procedure(5000.999999,NULL);

这篇关于存储过程加入动态sql的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129038

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp