分类目录归档:T-SQL

通用分页显示查询存储过程

/*
 功能描述: 通用分页显示查询
    条件:表中不存在标示递增字段
 输入参数:
    @tblName:  表名  
    @strGetFields: 需要返回的列 '*':返回所以列信息
    @fldName:  排序的字段名
    @OrderType:  设置排序类型, 非 0 值则降序
    @PageSize:  页尺寸
    @PageIndex:  页码
    @doCount:  返回记录总数, 非 0 值则返回
    @strOrderBy: 缺省排序字段信息 (注意: 不要加 ORDER BY)
        格式: Field1 DESC,Field2 ASC,
    @strWhere:  查询条件 (注意: 不要加 WHERE)
 输出参数: @RecordCount: 记录总数
 作    者: ningfeiyang
 创建时间: 2005-01-19
 更改纪录:
*/<!--more-->


ALTER PROCEDURE Pagination2
 (
  @tblName   varchar(255),
  @strGetFields varchar(1000) = '*',
  @fldName varchar(255) = '',
  @PageSize   int = 10,
  @PageIndex  int = 1,
  @doCount  bit = 0,
  @OrderType bit = 0,
  @strOrderBy varchar(500) = '',
  @strWhere  varchar(1500) = '',
  @RecordCount int output
 )
AS
 DECLARE @strSQL   varchar(5000)       -- 主语句
 DECLARE @strTmp   varchar(200)        -- 临时变量
 DECLARE @strOrder varchar(400)        -- 排序变量

 --如果@doCount传递过来的不是0,就执行总数统计
 IF (@doCount != 0)
 BEGIN
  DECLARE @sWhere varchar(2000)
  
  SET @sWhere = ''
  IF (@strWhere != '')
   SET @sWhere = ' WHERE ' + @strWhere
   
  SET @strSQL = 'if exists (select * from dbo.sysobjects where id = object_id(''[dbo].[tmpTable]'') and OBJECTPROPERTY(id, ''IsUserTable'') = 1) '
  SET @strSQL = @strSQL + ' UPDATE tmpTable SET Total = (SELECT COUNT(*) FROM [' + @tblName + '] ' + @sWhere + ') '
  SET @strSQL = @strSQL + ' ELSE SELECT COUNT(*) AS Total INTO tmpTable FROM [' + @tblName + '] ' + @sWhere
   
  EXEC (@strSQL)
  
  SELECT @RecordCount=Total FROM tmpTable
  
  --删除总数统计临时表
  EXEC ('DROP TABLE tmpTable')
 END
 
 --PRINT @RecordCount
 
 --如果@OrderType不是0,就执行降序
 IF (@OrderType != 0)
 BEGIN
  SET @strTmp = ' < (SELECT MIN'
  SET @strOrder = ' ORDER BY ' + @strOrderBy + '[' + @fldName + '] DESC'
 END
 ELSE
 BEGIN
  SET @strTmp = ' > (SELECT MAX'
  SET @strOrder = ' ORDER BY ' + @strOrderBy + '[' + @fldName + '] ASC'
 END

 --如果是第一页就执行以上代码,这样会加快执行速度
 IF @PageIndex = 1
 BEGIN
  IF @strWhere != ''   
   SET @strSQL = 'SELECT TOP ' + str(@PageSize) + ' ' + @strGetFields + '  FROM [' + @tblName + '] WHERE ' + @strWhere + ' ' + @strOrder
  ELSE
   SET @strSQL = 'SELECT TOP ' + str(@PageSize) + ' ' + @strGetFields + '  FROM ['+ @tblName + '] '+ @strOrder
 END
 ELSE
 BEGIN
  --为搜索表建立自动编号 保存到临时表中
  SET @strSQL = 'SELECT TOP ' + str(@PageIndex*@PageSize) + ' IDENTITY(int,1,1) AS IID, ' + @strGetFields + ' INTO #tmpTable FROM [' + @tblName + ']'
  IF @strWhere != ''
   SET @strSQL = @strSQL + ' WHERE ' + @strWhere + ' ' + @strOrder
  ELSE
   SET @strSQL = @strSQL + @strOrder
 
  --以下代码赋予了@strSQL以真正执行的SQL代码
  SET @strSQL = @strSQL + ' SELECT TOP ' + str(@PageSize) + ' ' + @strGetFields + ' FROM #tmpTable'
     + ' WHERE IID ' + @strTmp + '(IID) FROM (SELECT TOP ' + str((@PageIndex-1)*@PageSize) + ' IID FROM #tmpTable) AS tblTmp) DROP TABLE #tmpTable'
 END
 
 --PRINT @strSQL

 --执行分页查询
 EXEC (@strSQL)

查考文章:http://dev.csdn.net/develop/article/45/45356.shtm

SQL Server 存储层级数据实现无限级分类

由于数据库存储的数据都是以平面方式存储,所以目前大部分论坛和其他程序都是用递归来展现层次数据的,如果分类的层次十分深的话那么使用的递归次数相当可观,对性能的影响也非常大。最近要做一个分类信息的平台就遇到这个问题了,那么如何实现快速的展现分层数据呢?MYSQL 的开发者帮我们想到了一个算法,这个算法目前唯一的问题就是尚未实现分类排序,我们可以通过右值的反向排序实现先入先出的排序。在这里我们需要了解的是如何用 SQL Server 来实现,我们就以省市县数据库为例来实现:

如图所示我们将一个树节点的左右各编上号码,就可以看出一些规律,山西的左右值为(8,17),那么所有左值大于8,右值小于17的节点都是属于山西的子节点。稷山县的左右值为(14,15),那么他的所有父节点就是左值小于14,右值大于15的节点,怎么样,用这个方法实现的无限级分类性能绝对是顶呱呱的。一次查询就可以查出属于某个节点的数据以及他子节点的数据。这个算是我见过性能最高的无限级分类算法。其他算法跟这个对比基本没有任何优势。 继续阅读

Search and Replace in a TEXT(NTEXT)

MSSQL: Search and Replace in a TEXT(NTEXT) columnIt’s been a while since I’ve posted anything SQL related. So… Sometimes we need to search and replace a text value in the entire table. The column in question is of TEXT or NTEXT datatype. T-SQL REPLACE function does not work with TEXT/NTEXT datatype. 继续阅读

T-SQL Find and Replace

SQL Server Find and Replace Values in All Tables and All Text Columns

Problem
In a previous tip, Searching and finding a string value in all columns in a SQL Server table, you showed how to find a string value in any text column in any table in a database. I was wondering how this can be taken a step further to allow a replacement of text in a string data type for all columns and tables in my database. I have read about a SQL injection attack where text is inserted and this could be a good way to remove the offending text.
继续阅读