mysql 存储过程实现分页

重点:若参数是字符串,则需要在程序中拼接’‘或者"“;
字符串参数=String.format(”%s’", 字符串参数)

CREATE DEFINER=`root`@`%` PROCEDURE `A`( queryName varchar(64),entryStatus varchar(64),entryStartDate varchar(64),entryEndDate varchar(64),pageIndex INT(10),pageSize INT(10))
BEGIN
--  获取hr员工信息列表

-- pageIndex  当前页
-- pageSize   每页记录数

-- 总记录分页数
 declare pageCount   int(10); 
-- 总记录数
 declare totalRecordCount  int(10);
 
-- 用户名
SET @queryName = '';
-- 手机号
SET @queryPhone = '';

-- 入职状态
set @entryStatus='';


-- 入职日期范围查询
set @entryDate='';



 -- 名称和手机号作为一个搜素条件
                if queryName != '' and queryName is not null then
         SET @queryName = CONCAT("  and ( name  like ", queryName," or mobile  like ", queryName ,')' );
    END if;

                
                if entryStatus != '' and entryStatus is not null then
         SET @entryStatus = CONCAT(" and entry_status  = ", entryStatus );
    END if;
                
                
                if entryStartDate != '' and entryStartDate is not null and entryEndDate != '' and entryEndDate is not null then
         SET @entryDate = CONCAT(" and  DATE_FORMAT(entry_date,'%Y-%m-%d')  between ", entryStartDate,' and ', entryEndDate );
    END if;
                
                
                
                
                

    /*获取表中的记录数*/
    set @recordCount=0;
    set @sql='';
    set @sql=CONCAT('select count(*) into @recordCount from 表A where 1=1',  @queryName,@entryStatus,@entryDate);


   prepare stmt from @sql; /*预处理 自定义sql字符串*/
   execute stmt; /*执行自定义sql语句*/
   deallocate prepare stmt; /*释放预处理资源*/
   
   set totalRecordCount = @recordCount; /*总记录数*/
    
    /*计算返回多少页*/
   set @tmp=1;
    set @tmp=@recordCount mod pageSize; /*取余数*/
    if @tmp=0 then
     set pageCount=@recordCount div pageSize;
    else
     set pageCount=@recordCount div pageSize + 1;
   end if;
 

        
  /*分页显示数据*/
  set @sql=CONCAT("select * from 表A where 1=1",@queryName,@entryStatus,@entryDate," limit ",(pageIndex-1)*pageSize,",",pageSize);


   prepare stmt from @sql; /*预处理 自定义sql字符串*/
   execute stmt;/*执行自定义sql语句*/
   deallocate prepare stmt; /*释放预处理资源*/



-- 分页信息
   select totalRecordCount,pageCount;

                
END
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

博客胡

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值