【自用】无限级分类获取SQL语句

自定义函数:

 1 USE [ExpenseCenter_Fibrogen]
 2 GO
 3 /****** Object:  UserDefinedFunction [dbo].[GetSubordinateTable]    Script Date: 2014/10/11 13:24:32 ******/
 4 SET ANSI_NULLS ON
 5 GO
 6 SET QUOTED_IDENTIFIER ON
 7 GO
 8 ALTER FUNCTION [dbo].[GetSubordinateTable]
 9 (
10     @adaccount        nvarchar(128),
11     @includeResign    bit,
12     @allowMore        bit
13 )
14 RETURNS @SubordinateTable TABLE
15 (
16     ADAccount    nvarchar(128),
17     ChineseName    nvarchar(128),
18     EnglishName    nvarchar(128)
19 )
20 AS
21 Begin
22
23     Insert Into @SubordinateTable
24         Select ADAccount,ChineseName,EnglishName
25             From SystemUser Where ReportingUserADAccount = @adaccount
26                 And (@includeResign = 1 Or IsActive=1)
27
28     if @allowMore=1
29     Begin
30         declare @acc    nvarchar(128)
31         set @acc = ‘‘
32         while 1=1
33         Begin
34             Select Top 1 @acc = ADAccount From SystemUser Where ReportingUserADAccount = @adaccount And (@includeResign = 1 Or IsActive=1)
35                 And ADAccount>@acc Order By ADAccount
36
37             if @@ROWCOUNT=0
38                 break
39
40             Insert Into @SubordinateTable
41                 Select * From GetSubordinateTable(@acc,@includeResign,@allowMore)
42         End
43     End
44
45     RETURN
46 End

WITH函数(仅支持SQL SERVE 2008)

向上查找

1 WITH Users(ADAccount,ParentADAccount)
2 as
3 (
4     SELECT ADAccount,ReportingUserADAccount FROM SystemUser where ADAccount=‘fli‘
5  UNION ALL
6  SELECT A.ADAccount,ReportingUserADAccount FROM SystemUser A,Users b
7  where a.ADAccount = b.ParentADAccount
8 )
9 select * from Users

向下查找

1 WITH Users(ADAccount,ParentADAccount)
2 as
3 (
4     SELECT ADAccount,ReportingUserADAccount FROM SystemUser where ADAccount=‘xwang‘
5  UNION ALL
6  SELECT A.ADAccount,ReportingUserADAccount FROM SystemUser A,Users b
7  where a.ReportingUserADAccount = b.ADAccount
8 )
9 select * from Users
时间: 2024-10-11 16:43:50

【自用】无限级分类获取SQL语句的相关文章

应用系统如何分析和获取SQL语句的执行代码

大部分开发人员都有这样一个需求,在程序连接数据库执行时,有时需要获取具体的执行语句,以便进行相关分析,这次我向大家介绍一下通用权限管理系统提供的SQL语句执行跟踪记录,直接先看看代码吧:(这个功能我也是在看底层代码时发现的) namespace DotNet.Utilities { /// <summary> /// SQLTrace /// 记录SQL执行 Global 中设置 BaseSystemInfo.LogSQL=true 可以开启跟踪记录 /// /// /// 修改纪录 ///

巧用C# Split()函数获取SQL语句中操作字段

这是前天工作时要求的,将SQL语句的操作字段获取出来挂在树节点上,感觉这个函数以后还有可能会用到,特此总结一下,函数中没有实现Select *的操作,只要添加判断条件即可. 工具函数:Split()函数:通过字符分割字符串为一个string类型的一维数组. String.Split 方法有6个重载函数: 1) public string[] Split(params char[] separator)        返回的字符串数组包含此实例中的子字符串 2) public string[] S

使用Hibernate 拦截执行sql语句,并输出sql语句,获取sql语句

重建包名 org.hibernate.type.descriptor.sql 重建类BasicBinder 代码如下 package org.hibernate.type.descriptor.sql; import java.sql.PreparedStatement; import java.sql.SQLException; import org.hibernate.internal.CoreLogging; import org.hibernate.type.descriptor.Jdb

iBATIS.net获取运行时sql语句

[本文原创,第一次离首页如此之近.发在候选区攒攒rp,管理员看着不合适可以撤下.] 虽然只在iBatis的世界里小打小闹匆匆数月,却历经数次与领导和同事激辩,再通过不懈努力学习和开发积累,楼猪终于被它小巧而不失强大,稳定而不失灵活所折服.作为80后顽固.偏执和nc一族,楼猪一向保守认为自己是美貌与智慧并存的.仗着天资聪慧,在之前的“iBatis.net直接执行sql语句”里曾经公然抱怨iBATIS对sql语句的直接查看灰常的不友好,调试不方便,排除错误非常考验眼神,很重要的一条(甚至应该算是楼猪

获取linq生成的sql语句

命名空间:using System.Data.Objects; var query = db.TxtRes.Join(db.LangRes, a => new { id1 = a.ResID, id2 = a.ResID }, b => new { id1=b.ID,id2=b.ID }, (a, b) => new { a.ID, a.ResID, a.Lang, b.Key }); var objectQuery = query as System.Data.Objects.Obje

LINQ to SQL语句(1)之Where(抄的好)

Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句. Where操作包括3种形式,分别为简单形式.关系条件形式.First()形式.下面分别用实例举例下: 1.简单形式: 例如:使用where筛选在伦敦的客户 var q = from c in db.Customers where c.City == "London" select c; 再如:筛选1994 年或之后雇用的雇员:

LINQ to SQL语句非常详细(原文来自于网络)

LINQ to SQL语句(1)之Where Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句. Where操作包括3种形式,分别为简单形式.关系条件形式.First()形式.下面分别用实例举例下: 1.简单形式: 例如:使用where筛选在伦敦的客户 var q = from c in db.Customers where c.City == "London" select c

LINQ to SQL语句入门篇 纯属转载

Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句. Where操作包括3种形式,分别为简单形式.关系条件形式.First()形式.下面分别用实例举例下: 1.简单形式: 例如:使用where筛选在伦敦的客户 var q = from c in db.Customers where c.City == "London" select c; 再如:筛选1994 年或之后雇用的雇员:

Magento中直接使用SQL语句

原理: magento是基于Zend Framework的,所以底层用的还是zend的zend db 在文件app/code/core/Mage/Catalog/model/Resource/Eav /Mysql4/Config.php 中追踪到下面的函数 getAttributesUsedInListing() /*** Retrieve Product Attributes Used in Catalog Product listing** @return array*/public fun