真TMD爽,第一次找到复杂SQL的错误

2024-04-12 13:48

本文主要是介绍真TMD爽,第一次找到复杂SQL的错误,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以前用的ASPNetPager的存储过程今天突然错了,郁闷啊!

因为以前只是用,今天第一次研究。。。。

哈哈!居然让我找到了错误所在。。。 嘿嘿

越来越强烈的体会到procdeure的强大!

Alter PROCEDURE dbo.Code_SYS_PackSqlInPage
(
 @tblName varchar(255), -- 表名
 @strGetFields varchar(1000) = '*', -- 需要返回的列
 @fldName varchar(255)='', -- 排序的字段名
 @PageSize int = 10, -- 页尺寸
 @PageIndex int = '', -- 页码
 @OrderType bit = '', -- 设置排序类型, 非 0 值则降序
 @strWhere varchar(8000) = '' -- 查询条件 (注意: 不要加 where)
)
AS
BEGIN
declare @strSQLCount  nvarchar(4000) -- 主语句
declare @strSQL  nvarchar(4000) -- 主语句
declare @strTmp varchar(1000) -- 临时变量
declare @strOrder varchar(400) -- 排序类型
declare @sCRLF char(2)
declare @sTAB char(1)
SET @sTAB = char(9)
SET  @sCRLF = char(13) + char(10)
if @strWhere !=''
set @strSQLCount = 'select count(1) as Total from ' + (@tblName) + @sCRLF+'where 1 = 1'+@sCRLF+@strWhere
else
set @strSQLCount = 'select count(1) as Total from ' + (@tblName)
--以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况
if @OrderType = 0
BEGIN
 set @strTmp = '<'+@sCRLF+'('+@sCRLF+@sTAB+'select min'
 set @strOrder = 'order by ' + (@fldName)
 --如果@OrderType不是0,就执行降序,这句很重要!
END
else
BEGIN
 set @strTmp = '>'+@sCRLF+'('+@sCRLF+@sTAB+'select max'
 set @strOrder = 'order by ' + (@fldName) +' asc'
END
if @PageIndex = 1
BEGIN
if @strWhere != ''
 set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields +@sCRLF+ ' from ' + (@tblName) + ' where  1 = 1 ' + @sCRLF + @strWhere
 + @sCRLF + @strOrder
 else
 set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields +@sCRLF+ ' from '+ (@tblName) + ' '
 + @sCRLF + @strOrder
 --如果是第一页就执行以上代码,这样会加快执行速度
END
else
BEGIN
 --以下代码赋予了@strSQL以真正执行的SQL代码
 set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+@sCRLF+ 'from '
 + (@tblName)+@sCRLF+'where ' + (@fldName) + @strTmp +'('+ (@fldName) + ') from '+@sCRLF+@sTAB
 +'('+@sCRLF+@sTAB+@sTAB
 +'select top ' + str((@PageIndex-1)*@PageSize) + ' '+ (@fldName) + ' from ' + (@tblName)
 
 if (len(@strWhere)>0)
  set @strSQL = @strSQL + ' where  1 = 1 ' + @sCRLF + @strWhere + ' '
 
-- select @strSQL as SQLCommand1
 set @strSQL = @strSQL+@sCRLF+@strOrder+@sCRLF+@sTAB
-- set @strSQL = @strSQL+@sCRLF+@sTAB
 + ')'+' as tblTmp'+@sCRLF
 +')'
 if (len(@strWhere)>0)
  set @strSQL = @strSQL + @sCRLF + @strWhere +@sCRLF
 set @strSQL = @strSQL + @strOrder
-- select @strSQL as SQLCommand
END
 exec(@strSQL)
 exec(@strSQLCount)
END

GO

这篇关于真TMD爽,第一次找到复杂SQL的错误的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Mysql中InnoDB与MyISAM索引差异详解(最新整理)

《Mysql中InnoDB与MyISAM索引差异详解(最新整理)》InnoDB和MyISAM在索引实现和特性上有差异,包括聚集索引、非聚集索引、事务支持、并发控制、覆盖索引、主键约束、外键支持和物理存... 目录1. 索引类型与数据存储方式InnoDBMyISAM2. 事务与并发控制InnoDBMyISAM

SpringBoot实现导出复杂对象到Excel文件

《SpringBoot实现导出复杂对象到Excel文件》这篇文章主要为大家详细介绍了如何使用Hutool和EasyExcel两种方式来实现在SpringBoot项目中导出复杂对象到Excel文件,需要... 在Spring Boot项目中导出复杂对象到Excel文件,可以利用Hutool或EasyExcel

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据

《mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据》文章主要介绍了如何从.frm和.ibd文件恢复MySQLInnoDB表结构和数据,需要的朋友可以参... 目录一、恢复表结构二、恢复表数据补充方法一、恢复表结构(从 .frm 文件)方法 1:使用 mysq

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

MySQL进阶之路索引失效的11种情况详析

《MySQL进阶之路索引失效的11种情况详析》:本文主要介绍MySQL查询优化中的11种常见情况,包括索引的使用和优化策略,通过这些策略,开发者可以显著提升查询性能,需要的朋友可以参考下... 目录前言图示1. 使用不等式操作符(!=, <, >)2. 使用 OR 连接多个条件3. 对索引字段进行计算操作4