谈谈Java调用SQL Server分页存储过程

本文主要谈谈Java调用SQL Server分页存储的过程,其返回是多个结果集,只要呈现形式是代码,文字不多,简单易懂。

SQL存储过程:

  1. USE [Db_8za8za_2]     
  2. GO     
  3.     
  4. SET ANSI_NULLS ON     
  5. GO     
  6. SET QUOTED_IDENTIFIER ON     
  7. GO     
  8. -- =============================================     
  9. -- Description:    <Description,,通用分页存储过程>     
  10. -- =============================================     
  11. ALTER PROCEDURE [dbo].[paging ]     
  12.     -- Add the parameters for the stored procedure here     
  13.     --传入参数     
  14.     @SqlStr nvarchar(4000), --查询字符串     
  15.     @CurrentPage int--第N页(当前页数)     
  16.     @PageSize int --每页行数     
  17. AS     
  18. BEGIN     
  19.     -- SET NOCOUNT ON added to prevent extra result sets from     
  20.     -- interfering with SELECT statements.     
  21.     SET NOCOUNT ON;     
  22.     --定义变量     
  23.     DECLARE @CursorId int --CursorId是游标的id     
  24.     DECLARE @Rowcount int --总记录(行)数     
  25.     DECLARE @pageCount int --总页数     
  26.     -- Insert statements for procedure here     
  27.         
  28.     EXEC sp_cursoropen @CursorId output,@SqlStr,     
  29.         @Scrollopt=1,@Ccopt=1,@Rowcount=@Rowcount OUTPUT     
  30.         
  31.     SET @pageCount=CEILING(1.0*@Rowcount/@PageSize)--设置总页数     
  32.         
  33.     SELECT @pageCount     
  34.         AS 总页数,@Rowcount AS 总行数,@CurrentPage AS 当前页 --提示页数     
  35.     
  36.     IF(@CurrentPage>@pageCount)--如果传入的当前页码大入总页码数则把当前页数设为***一页     
  37.         BEGIN     
  38.             SET @CurrentPage = @pageCount--设置当前页码数     
  39.         END     
  40.     IF(@CurrentPage<=0)--如果传入的当前页码大入总页码数则把当前页数设为***页     
  41.         BEGIN     
  42.             SET @CurrentPage = 1--设置当前页码数     
  43.         END     
  44.     SET @CurrentPage=(@CurrentPage-1)*@PageSize+1 --设置当前页码数     
  45.     
  46.     EXEC sp_cursorfetch @CursorId,16,@CurrentPage,@PageSize     
  47.     EXEC sp_cursorclose @CursorId    --关闭游标     
  48.     
  49.     SET NOCOUNT OFF     
  50. END   

#p#

Java调用储存过程:

  1. package test;    
  2.     
  3. import java.sql.*;    
  4.     
  5. public class Study3 {    
  6.     private Connection con;    
  7.     public ResultSet rs;    
  8.     private CallableStatement callsta;    
  9.     private String use = "sa";    
  10.     private String pwd = "sa";    
  11.     
  12.     public Study3() {    
  13.         try {    
  14.             // 连接数据库驱动    
  15.             Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");    
  16.             String str = "jdbc:microsoft:sqlserver://localhost:1433;databasename=test";    
  17.             con = DriverManager.getConnection(str, use, pwd);    
  18.     
  19.             // 设置存储过程参数    
  20.             String st = "{call Paging(?,?,?)}";    
  21.             callsta = con.prepareCall(st);    
  22.             callsta.setString(1"select * from T_employee");    
  23.             callsta.setInt(21);    
  24.             callsta.setInt(33);    
  25.     
  26.             // 循环输出调用存储过程的记录结果    
  27.             StringBuffer sb=new StringBuffer();    
  28.             int rsNum=0;//统计结果集的数量    
  29.             int updateCount = -1;    
  30.             boolean flag = callsta.execute();// 这个而尔值只说明***个返回内容是更新计数还是结果集。    
  31.             do {    
  32.                 updateCount = callsta.getUpdateCount();    
  33.                 if (updateCount != -1) {// 说明当前行是一个更新计数    
  34.                     // 处理.    
  35.                     System.out.println("..说明当前行是一个更新计数..");    
  36.                     callsta.getMoreResults();    
  37.                     continue;// 已经是更新计数了,处理完成后应该移动到下一行    
  38.                     // 不再判断是否是ResultSet    
  39.                 }    
  40.                 rs = callsta.getResultSet();    
  41.                 if (rs != null) {// 如果到了这里,说明updateCount == -1    
  42.                     // 处理rs    
  43.                     rsNum++;    
  44.                     System.out.println("统计结果集的数量:"+rsNum);    
  45.                     if (rs != null) {    
  46.                         ResultSetMetaData rsmd = rs.getMetaData(); // 获取字段名    
  47.                         int numberOfColumns = rsmd.getColumnCount(); // 获取字段数    
  48.                         int i = 0;    
  49.                         while (rs.next()) { // 将查询结果取出    
  50.                             for (i = 1; i <= numberOfColumns; i++) {    
  51. //                              System.out.println(rs.getInt("总页数"));    
  52.                                 String date = rs.getString(i);    
  53.                                 sb.append(date+" ");    
  54.                             }    
  55.                         }    
  56.                         rs.close();    
  57.                     }    
  58.                     callsta.getMoreResults();    
  59.                     continue;    
  60.                     // 是结果集,处理完成后应该移动到下一行    
  61.                 }    
  62.                 // 如果到了这里,说明updateCount == -1 && rs == null,什么也没的了    
  63.                 System.out.println(sb.toString());    
  64.             } while (!(updateCount == -1 && rs == null));    
  65.             // callsta.getXXX(int);//获取输出参数    
  66.         } catch (Exception e) {    
  67.             e.printStackTrace();    
  68.         }    
  69.     }    
  70.     
  71.     public static void main(String[] age) {    
  72.         Study3 study = new Study3();    
  73.     }    
  74. }   

原文链接:http://chenyunhong.iteye.com/blog/1096195

【编辑推荐】

  1. 说说Top子句对查询计划的影响
  2. SQL Server复灾 你懂了吗?
  3. SQL Server管理 这些你懂吗?
  4. 用一句SQL解决SQL中断号问题
  5. 如何用Java操作MongoDB

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/229019.html<

(0)
运维的头像运维
上一篇2025-04-18 14:01
下一篇 2025-04-18 14:03

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注