通用的SQL数据分页存储过程

CREATE  PROCEDURE spGetPageOfRecords
   @pageSize  int  =  20,                                       --  分页大小
   @currentPage  int ,                                   --  第几页
   @columns  varchar( 1000=  ' * ',                         --  需要得到的字段
   @tableName  varchar( 100),                                --  需要查询的表    
   @condition  varchar( 1000=  '',                       --  查询条件, 不用加where关键字
   @ascColumn  varchar( 100=  '',                        --  排序的字段名 (即 order by column asc/desc)
   @bitOrderType  bit  =  0,                                  --  排序的类型 (0为升序,1为降序)
   @pkColumn  varchar( 50=  ''                              --  主键名称

AS
BEGIN                                                                                    
   DECLARE  @strTemp  varchar( 300)
   DECLARE  @strSql  varchar( 5000)                             --  该存储过程最后执行的语句
   DECLARE  @strOrderType  varchar( 1000)                     --  排序类型语句 (order by column asc或者order by column desc)

   BEGIN
     IF  @bitOrderType  =  1                                         --  降序
       BEGIN
         SET  @strOrderType  =  '  ORDER BY  ' + @ascColumn + '  DESC '
         SET  @strTemp  =  ' <(SELECT min '
       END
     ELSE                                                                       --  升序
       BEGIN
         SET  @strOrderType  =  '  ORDER BY  ' + @ascColumn + '  ASC '
         SET  @strTemp  =  ' >(SELECT max '
       END

     IF  @currentPage  =  1                                                 --  第一页
       BEGIN
         IF  @condition  !=  ''
           SET  @strSql  =  ' SELECT TOP  ' + STR( @pageSize) + '   ' + @columns + '  FROM  ' + @tableName +
             '  WHERE  ' + @condition + @strOrderType
         ELSE
           SET  @strSql  =  ' SELECT TOP  ' + STR( @pageSize) + '   ' + @columns + '  FROM  ' + @tableName + @strOrderType
       END

     ELSE                                                                       --  其他页
       BEGIN
         IF  @condition  != ''
           SET  @strSql  =  ' SELECT TOP  ' + STR( @pageSize) + '   ' + @columns + '  FROM  ' + @tableName +
           '  WHERE  ' + @condition + '  AND  ' + @pkColumn + @strTemp + ' ( ' + @pkColumn + ' ) ' + '  FROM (SELECT TOP  ' + STR(( @currentPage - 1) * @pageSize) +
           '   ' + @pkColumn + '  FROM  '  +  @tableName  +  '  where  '  +  @condition + @strOrderType + ' ) AS TabTemp) ' + @strOrderType
         ELSE
           SET  @strSql  =  ' SELECT TOP  ' + STR( @pageSize) + '   ' + @columns + '  FROM  ' + @tableName +
           '  WHERE  ' + @pkColumn + @strTemp + ' ( ' + @pkColumn + ' ) ' + '  FROM (SELECT TOP  ' + STR(( @currentPage - 1) * @pageSize) + '   ' + @pkColumn +
           '  FROM  ' + @tableName + @strOrderType + ' ) AS TabTemp) ' + @strOrderType
       END

   END
  
   EXEC ( @strSql)
END 

 

执行代码如下:

--   Test Employees Table on Northwind database
EXEC spGetPageOfRecords  52' EmployeeID, LastName, FirstName, Title, City, Region, Country '' Employees '''' EmployeeID '0' EmployeeID '


--   Test Customers Table on Northwind database
EXEC spGetPageOfRecords  106' CustomerID, CompanyName, ContactName, ContactTitle, Address, City, Region, Country '' Customers '''' CustomerID '0' CustomerID '

 

 

### 关于ArcGIS License Server无法启动的解决方案 当遇到ArcGIS License Server无法启动的情况时,可以从以下几个方面排查并解决问题: #### 1. **检查网络配置** 确保License Server所在的计算机能够被其他客户端正常访问。如果是在局域网环境中部署了ArcGIS Server Local,则需要确认该环境下的网络设置是否允许远程连接AO组件[^1]。 #### 2. **验证服务状态** 检查ArcGIS Server Object Manager (SOM) 的运情况。通常情况下,在Host SOM机器上需将此服务更改为由本地系统账户登录,并重启相关服务来恢复其正常工作流程[^2]。 #### 3. **审查日志文件** 查看ArcGIS License Manager的日志记录,寻找任何可能指示错误原因的信息。这些日志可以帮助识别具体是什么阻止了许可证服务器的成功初始化。 #### 4. **权限问题** 确认用于启动ArcGIS License Server的服务账号具有足够的权限执所需操作。这包括但不限于读取/写入特定目录的权利以及与其他必要进程通信的能力。 #### 5. **软件版本兼容性** 保证所使用的ArcGIS产品及其依赖项之间存在良好的版本匹配度。不一致可能会导致意外为或完全失败激活license server的功能。 #### 示例代码片段:修改服务登录身份 以下是更改Windows服务登录凭据的一个简单PowerShell脚本例子: ```powershell $serviceName = "ArcGISServerObjectManager" $newUsername = ".\LocalSystemUser" # 替换为实际用户名 $newPassword = ConvertTo-SecureString "" -AsPlainText -Force Set-Service -Name $serviceName -StartupType Automatic New-ServiceCredential -ServiceName $serviceName -Account $newUsername -Password $newPassword Restart-Service -Name $serviceName ``` 上述脚本仅作为示范用途,请依据实际情况调整参数值后再实施。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值