无限级分类(非递归算法/存储过程版/GUID主键)完整数据库示例_(2)插入记录

简介: -- ======================================== -- Author:   -- Description:  -- Return     : 成功返回0,重名返回1 -- ======================================== Create PROCEDURE [dbo].

-- ========================================
-- Author:  <杨俊明,jimmy.yang@cntvs.com>
-- Description: <无限级分类插入记录>
-- Return     : 成功返回0,重名返回1
-- ========================================
Create PROCEDURE [dbo].[up_Class_InsertEx]
 @newId uniqueidentifier, --新记录Id 
 @classType nvarchar(50), --类型(比如:产品,新闻,地区)
 @parentId uniqueidentifier, --父类Id
 @className nvarchar(50), --分类名称
 @classReadMe nvarchar(200) --分类说明 
AS
BEGIN 
 SET NOCOUNT ON; 
 Declare @RootID int;     --根ID(顶级分类的RootID)
 DeClare @ParentName nvarchar(500);  --父类名称
 Declare @Depth int;      --父类深度
 Declare @MaxOrders int;     --同级最大排序号
 Declare @ParentIdStr nvarchar(500);  --父类Id全路径
 Declare @ParentNameStr nvarchar(500); --父类名称全路径 
 
 --如果是顶级类
 if @parentId='00000000-0000-0000-0000-000000000000'
 begin
  if not exists(select F_id From T_Class where F_ClassName=@className and F_type=@ClassType and F_parentid='00000000-0000-0000-0000-000000000000')  
  begin
   set @RootID = 0   
   if exists(select F_id From T_Class Where F_type=@ClassType and F_parentid='00000000-0000-0000-0000-000000000000')
   begin
    select @RootId = max(F_RootID) From T_Class Where F_type=@ClassType and F_parentid='00000000-0000-0000-0000-000000000000';--得到当前顶级分类的最大RootId    
   end 
        
   insert into T_Class(
    F_Id,
    F_Type,
    F_parentId,
    F_className,
    F_ReadMe,
    F_parentIdstr,
    F_parentNameStr,
    F_RootId,
    F_orders)
   values(
    @newId,
    @classType,
    '00000000-0000-0000-0000-000000000000',
    @className,
    @classReadMe,
    '00000000-0000-0000-0000-000000000000',
    '00000000-0000-0000-0000-000000000000',
    @rootId+1,
    0)
   return 0;--顶级分类成功插入
  end
  else
   return 1;--顶级分类已经存在
 end

 --如果不是顶级类
 if @parentId<>'00000000-0000-0000-0000-000000000000'   
 begin
  --检查父类ID的合法性
  if exists(select F_id From T_Class Where F_id=@parentID)  
  begin
   --检查该节点是否已经存在  
   if not exists(select F_id From T_Class where F_ClassName=@className and F_type=@ClassType and F_parentid=@parentId)   
   begin      
    select @rootId=F_RootId,@ParentName=F_ClassName,@Depth=F_Depth,@parentIdStr=F_parentIdStr,@parentNameStr=F_parentNameStr From T_Class Where F_Id = @ParentId;    
    set @maxOrders = 0
    --如果父类无子类
    if not exists(select F_id From T_Class where F_ParentIdStr like '%' + Convert(Nvarchar(50),@parentId) + '%')     
     select @maxOrders = F_orders From T_Class where F_id=@parentId    
    else
     select @maxOrders = Max(F_orders) From T_Class where F_ParentIdStr like '%' + Convert(Nvarchar(50),@parentId) + '%'           
           

    insert into T_Class(
     F_ID,
     F_Type,
     F_parentId,
     F_className,
     F_ReadMe,
     F_parentIdstr,
     F_parentNameStr,
     F_Orders,
     F_Depth,
     F_RootId  
     )
    values(
     @newId,
     @classType,
     @parentId,
     @className,
     @classReadMe,
     @parentIdStr + ',' + convert(nvarchar(50),@parentID),
     @parentNameStr + ',' + @parentName,
     @maxOrders + 1,
     @depth + 1,
     @rootId
     )
 
    update T_class set F_orders = F_orders + 1 where (F_orders > @maxOrders) And (F_RootId=@RootId) And F_ID<>@NewId 
 
    
    return 0;  
   end
   else
    return 1;
  end
 end 
END

目录
相关文章
|
3天前
|
关系型数据库 数据库 索引
关系型数据库主键的非空性
【5月更文挑战第15天】
14 2
|
3天前
|
关系型数据库 数据库 索引
关系型数据库主键的唯一性
【5月更文挑战第15天】
11 2
|
2天前
|
关系型数据库 数据库 数据库管理
|
2天前
|
算法 关系型数据库 数据库
|
2天前
|
关系型数据库 数据库
关系型数据库表结构设计的主键的简单性
【5月更文挑战第16天】关系型数据库表结构设计的主键的简单性
11 2
|
3天前
|
关系型数据库
关系型数据库主键的稳定性
【5月更文挑战第15天】
14 1
|
3天前
|
存储 关系型数据库 数据库
关系型数据库主键的唯一性
【5月更文挑战第15天】
12 1
|
5天前
|
算法 关系型数据库 数据库
关系型数据库表结构设计选择合适的主键
【5月更文挑战第13天】关系型数据库表结构设计选择合适的主键
19 3
|
11天前
|
算法 Go 分布式数据库
构建高可用的分布式数据库集群:使用Go语言与Raft共识算法
随着数据量的爆炸式增长,单一数据库服务器已难以满足高可用性和可扩展性的需求。在本文中,我们将探讨如何使用Go语言结合Raft共识算法来构建一个高可用的分布式数据库集群。我们不仅会介绍Raft算法的基本原理,还会详细阐述如何利用Go语言的并发特性和网络编程能力来实现这一目标。此外,我们还将分析构建过程中可能遇到的挑战和解决方案,为读者提供一个完整的实践指南。
|
11天前
|
存储 数据库
sqlserver------数据库的存储过程(练习)
sqlserver------数据库的存储过程(练习)
13 1