超强存储过程

转载 2004年09月14日 12:53:00
 在开发数据库应用程序中,我们经常需要表示多层次关系的数据,譬如:MRP中的BOM,多级别的组织结构,多级的角色关系…… 在数据库中描述这种关系时,我们通常使用父节点指向的方式来设计表结构,譬如对部门的表结构定义如下:

  CREATE TABLE TDepartment
  (
    ParentNo varchar(25),    /* 上级部门编号,如果为NULL则表示当前记录为顶级部门。 */
    DepartmentNo varchar(25) PRIMARY KEY CLUSTERED/* 当前部门编号,主关键字段。 */
    Name  nvarchar(100) NOT NULL,   /* 部门名称。 */
    NameEx  nvarchar(100),    /* 扩展名称。 */
    Remark  nvarchar(500)    /* 备  注。 */
  )

  功能需求:获取指定部门编号及其所属的所有或指定层次的下级部门的记录集。

  在以往的开发中,我们通常是在客户端或者中间层来处理以上需求的,一般是通过编程语言(VB、Delphi、Java/.NET)来处理从数据库返回的记录集,这种方式通常需要从数据库获得整个表的记录,因为我们不能确定给定主键所具有的哪些下级记录,然后再在编程代码中使用递归的方式来获取相关的下级记录。这种使用递归的方式,通常难以避免数据中非法记录所引起的死循环问题(当然,你也可以处理这种问题,只是有些麻烦,而且通常也不够优美)。那么,能不能在数据库中就处理好这个问题呢,这样既能减少不必要的数据传输,又能避免使用递归所带来的负面影响,最好还能自动屏蔽掉非法数据指向的问题(当前记录的父指针字段指向其某个下级记录)。
  呵呵,卖弄完毕,亮出匕首(代码,Transact-SQL/MS-SQLServer 2000):

/* Copyright all(c) 2004 ZhongFeng, http://blog.csdn.net/SW515 */
CREATE PROCEDURE dbo.PSelectDepartmentHierarchy
  @DepartmentNo    varchar(25),
  @Depth           int  = -1
AS
  SET NOCOUNT ON

  DECLARE @TStack TABLE
  (
    Indicator varchar(50)
  )

  DECLARE @Index int
  SET @Index = 0

  INSERT INTO @TStack
    SELECT DepartmentNo
    FROM dbo.TDepartment
    WHERE DepartmentNo LIKE @DepartmentNo

  WHILE @@ROWCOUNT > 0 AND (@Index < @Depth OR @Depth < 0)
  BEGIN
    SET @Index = @Index + 1

    INSERT INTO @TStack
      SELECT DepartmentNo
      FROM dbo.TDepartment
      WHERE
        ParentNo IN (SELECT Indicator FROM @TStack) AND
        
DepartmentNo NOT IN (SELECT Indicator FROM @TStack)
  END

  SELECT dbo.TDepartment.*
  FROM @TStack AS t
    INNER JOIN dbo.TDepartment ON
      t.Indicator = dbo.TDepartment.DepartmentNo
GO

作者Blog:http://blog.csdn.net/SW515/

超强OCR文字识别软件首选ABBYY FineReader

提到纸质文档—转换—文本格式—可编辑这些字眼,相信大家的第一反映都是OCR文字识别软件,如何排除错误或利用辅助信息提高识别正确率,是OCR最重要的课题,衡量一个OCR系统性能好坏的主要指标无非是精确度...
  • ABBYY2015
  • ABBYY2015
  • 2017年04月25日 09:49
  • 558

超强PCB布线设计经验谈附原理图

在当今激烈竞争的电池供电 市场中,由于成本指标限制,设计人员常常使用双面板。尽管多层板(4层、6层及8层)方案在尺寸、噪声和性能方面具有明显优势,成本压力却促使工程师们重新考虑其布线策略,采用双面板。...
  • Tele_Anti_Nomy
  • Tele_Anti_Nomy
  • 2016年07月28日 20:59
  • 1344

《增强现实:融合现实与虚拟世界》

空间增强现实:融合现实和虚拟世界 2016年2月18日      上海普陀区 翻译:Taylor Guo ...
  • BBZZ2
  • BBZZ2
  • 2016年06月28日 11:11
  • 1840

自定义TabLayout的实现

前言项目需要做一个选项卡的功能,很简单,就是点击切换的效果,公共有这个控件,但是不太符合业务需求,所以自己花了半小时写了一个,很简单,继承自linearLayout,支持预置选择哪个选项卡,支持显示红...
  • wzlyd1
  • wzlyd1
  • 2016年08月24日 18:56
  • 3459

sscanf的超强用法

sscanf函数用法详解 作者: 来源:   名称:    sscanf() - 从一个字符串中读进与指定格式相符的数据.    函数原型:    Int sscanf( strin...
  • tianyuhang123
  • tianyuhang123
  • 2016年07月13日 11:29
  • 134

超强配置的vim

用vim打造理想的IDE简介前言对于一个开发者而言,使用vim可以说是又爱又恨,一个追求高效的开发者决不能容忍一个开发工具不能自动补全,没有目录导航和函数导航,参考 vim实用技巧实用技巧后,我将常用...
  • yonggeit
  • yonggeit
  • 2017年05月13日 15:08
  • 728

超强vim配置文件[转]

原文:强大的vim配置文件,让编程更随意该vim配置主要有以下优点: 按F5可以直接编译并执行C、C++、java代码以及执行shell脚本,按F8可进行C、C++代码的调试 自动插入文件头 ,新建C...
  • u011475134
  • u011475134
  • 2017年07月27日 16:37
  • 99

超强的代数运算

人=吃饭+睡觉+上班+玩,猪=吃饭+ 睡觉,代入:人=猪+上班+玩,即:人-玩=猪+上班.结论:不懂玩的人=会上班的猪 男人=吃饭+ 睡觉+挣钱猪=吃饭+ 睡觉男人=猪+挣钱猪=男人-挣钱所以男人...
  • king201210
  • king201210
  • 2013年08月28日 14:32
  • 160

OllyDBG完美教程(超强入门级)

OllyDBG完美教程(超强入门级)   2013-05-12 22:10:43|  分类: 工具|举报|字号 订阅      ...
  • metasearch
  • metasearch
  • 2016年10月20日 22:35
  • 810

超强的linux 一句话 命令

1.删除0字节文件 find -type f -size 0 -exec rm -rf {} \; 2.查看进程 按内存从大到小排列 ps -e  -o "%C  : %p : %z : %a...
  • CAIYAODENG
  • CAIYAODENG
  • 2014年12月03日 12:53
  • 328
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:超强存储过程
举报原因:
原因补充:

(最多只允许输入30个字)