Sql [hierarchyid]類型如何動態插入層級數據

来源:http://www.cnblogs.com/sunkaixuan/archive/2016/02/27/5222810.html
-Advertisement-
Play Games

[hierarchyid] 是個不錯的數據類型,提供了很方便並且高性能的樹型查詢,網上找了很多資料都沒有講到如何做到動態插入這個關鍵點,從MSDN認真看了下資料寫出了一個DEMO CREATE TABLE EmployeeOrg ( OrgNode hierarchyid PRIMARY KEY C


[hierarchyid] 是個不錯的數據類型,提供了很方便並且高性能的樹型查詢,網上找了很多資料都沒有講到如何做到動態插入這個關鍵點,從MSDN認真看了下資料寫出了一個DEMO

CREATE TABLE  EmployeeOrg
(
   OrgNode hierarchyid PRIMARY KEY CLUSTERED,
   OrgLevel AS OrgNode.GetLevel(),
   EmployeeID int UNIQUE NOT NULL,
   EmpName varchar(20) NOT NULL,
   Title varchar(20) NULL
) ;
go

CREATE PROC AddEmp(@mgrid int, @empid int, @e_name varchar(20), @title varchar(20)) 
AS 
BEGIN
   DECLARE @mOrgNode hierarchyid, @lc hierarchyid
   SELECT @mOrgNode = OrgNode 
   FROM  EmployeeOrg 
   WHERE EmployeeID = @mgrid
   SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
   BEGIN TRANSACTION
      SELECT @lc = max(OrgNode) 
      FROM  EmployeeOrg 
      WHERE OrgNode.GetAncestor(1) =@mOrgNode ;

      INSERT  EmployeeOrg (OrgNode, EmployeeID, EmpName, Title)
      VALUES(@mOrgNode.GetDescendant(@lc, NULL), @empid, @e_name, @title)
   COMMIT
END ;

go

--插入根
INSERT  EmployeeOrg (OrgNode, EmployeeID, EmpName, Title)
VALUES (hierarchyid::GetRoot(), 1, '藍燈', 'Marketing Manager') 
go
--隨機數
declare @p1 int
select @p1=convert(int, 100000000*rand())
declare @p2 int
select @p2=convert(int, 100000000*rand())

--插入軟體部門子集
EXEC AddEmp 1, @p1, '研發部門老大', 'Marketing Specialist' ;
EXEC AddEmp 1, @p2, '測試部門老大', 'Marketing Specialist' ;

go

select * from EmployeeOrg

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • (一),使用dispatch_set_target_queue更改Dispatch Queue的執行優先順序 dispatch_queue_create函數生成的DisPatch Queue不管是Serial DisPatch Queue還是Concurrent Dispatch Queue,執行的優
  • Linux環境中,安裝好mysql後,還不能直接啟動服務,必須先對資料庫進行初始化。初始化的工作主要包括: 初始化日誌、表空間等資料庫必須的文件; 創建並初始化系統資料庫(mysql)。 初始化完成後,啟動mysqld守護進程,方可訪問資料庫。 在Windows的環境下,安裝包內已經自帶了一個初始化
  • Oracle中常用的命令和函數,做個整理,以備以後用到,方便查閱。常用命令: 連接sqlplus命令行下運行cmd進入,如以sys模式登陸,命令如下:(1).sqlplus "sys/zhb126 as sysdba" (2).sqlplus/nolog connect sys/zhb126 as
  • 先在系統表中找到要處理的表名或者是存儲過程的名字,在用游標對其進行處理 PS:SqlServer 2000使用的是系統表是sysobjects,類型欄位是:xtype; SqlServer 2005以上版本的系統表是Sys.Objects,類型欄位是Type 本文中以Sql2005為例,Sql200
  • MyISAM 優點:快速讀取數據, 占用空間小 缺點:不支持事務,外鍵 (表級別鎖) InnoDB 優點:支持事務,外鍵; 高性能(CPU效率高) 缺點: 慢,占空間 (行級別鎖)
  • 1、serverCron簡介 在 Redis 中, 常規操作由 redis.c/serverCron 實現, 它主要執行以下操作 /* This is our timer interrupt, called server.hz times per second. * Here is where we
  • 要快點看論文了,寒假要看完的論文最後又是被拖到了最後幾天弄完../(ㄒoㄒ)/~~ 閑暇之時多記些linux命令,省著以後用再總去查了。 ************************************* 原文地址 CSDN(Linux小白學習入門過程): http://blog.csdn.
  • 在互聯網時代,網站就像一個公司的名片,擁有一個優秀的網站可以幫助企業樹立良好、可信的企業形象。其次,隨著網路經濟的發展,對於一些特殊的行業,企業網站還能夠為企業帶來直接的網路訂單。 本文介紹如何快速製作與發佈網站。製作網站一般選用HTML、CSS、JQuery語言,涉及後臺代碼才會運用到.NET、P
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...