SQL Server 常用內置函數(built-in)持續整理

来源:http://www.cnblogs.com/ljhdo/archive/2016/12/17/5780034.html
-Advertisement-
Play Games

本文用於收集在運維中經常使用的系統內置函數,持續整理中 一,常用Metadata函數 1,查看資料庫的ID和Name 2,查看對象的ID和Name,對象的Schema,對象的定義 3,查看Schema的ID和Name,通過對象ID獲取對象的架構名(Schema) 4,查看Column的Name 二, ...


本文用於收集在運維中經常使用的系統內置函數,持續整理中

一,常用Metadata函數

1,查看資料庫的ID和Name

db_id(‘DB Name’),db_name('DB ID')

2,查看對象的ID和Name,對象的Schema,對象的定義

OBJECT_ID ( 'schema_name . object_name','object_type' ) 
OBJECT_NAME ( object_id [, database_id ] ) 
OBJECT_SCHEMA_NAME ( object_id [, database_id ] )
OBJECT_DEFINITION ( object_id ) 

3,查看Schema的ID和Name,通過對象ID獲取對象的架構名(Schema)

SCHEMA_NAME ( [ schema_id ] )  
SCHEMA_ID ( [ schema_name ] ) 
OBJECT_SCHEMA_NAME ( object_id [, database_id ] )  

4,查看Column的Name

COL_NAME(table_id,column_id)

二,常用Security Function

1,當前資料庫User的Name(Database User)

CURRENT_USER

2,查看資料庫User的Name 和ID(Database User)

USER_NAME ( [ id ] )
USER_ID ( [ 'user' ] )
USER_SID()
DATABASE_PRINCIPAL_ID ( 'principal_name' )  

3,查看伺服器User的Name和ID(Server User,即Login)

Login(登錄)是伺服器主體(Server Principal),有Name和ID屬性,每一個Login都有一個安全標識(SID)。

--返回Login ID,參數是Login Name
SUSER_ID ( ['login'] )            
--返回Login Name,參數是Login ID,         
SUSER_NAME ( [login_id] )
--返回SID(security identification),參數是Login Name
SUSER_SID ( ['login'] [ , Param2 ] )    
--返回Login Name,參數是SID
SUSER_SNAME ( [SID] )    

4,SID和ID的區別

當創建一個SQL Server Login時,從sys.server_principals 系統視圖中,能夠看到該Login被指定一個ID和SID,在SQL Server實例中,ID和SID都是唯一的,不同之處是,ID標識Login,將Login作為一個Securable ,SID標識Login的Security Context。一般來說,ID可以重用,但是SID一般是不會重用的。當將同一個Login重覆創建時,其ID可能發生變化,但是其SID不變。

不僅Login有ID和SID,Database User也有。當一個database users創建時,從sys.database_principals中,能夠看到該User被指定一個ID和SID。在資料庫級別,ID是唯一的。如果User是從SQL Server Login創建的,那麼User和Login的SID相同。 詳情,請參考《SIDs and IDs

三,常用全局變數

1,SQL Server的Name,ServiceName和版本

@@SERVERNAME,@@SERVICENAME,@@VERSION

2,返回當前module的ID,module包括:SP,UDF,Trigger

@@PROCID

--獲取當前Module Name
declare @ObjectName sysname;
select @ObjectName=object_name(@@ProcID)

3,返回當前Session的ID,當前的RequestID

@@SPID
CURRENT_REQUEST_ID() 

4,在當前Session中,返回上一條Query影響的數據行數量

@@ROWCOUNT 
ROWCOUNT_BIG ( ) 

5,當前Connection中,返回已開啟,但未結束的事務數量,查看當前事務的ID,和事務的狀態(1,0,-1)

XACT_STATE() 函數返回事務的狀態,1表示有Active Transaction,0表示沒有Active Transaction,-1表示有Active Transaction,但是有錯誤發生導致該事務未被提交。

@@TRANCOUNT 
CURRENT_TRANSACTION_ID( ) 
XACT_STATE() 

6,查看當前機器(Host)的名字(Machine Name和ID)

HOST_NAME () ,HOST_ID()

四,使用GZIP algorithm壓縮數據和解壓縮數據

COMPRESS ( expression ) 
DECOMPRESS ( expression )

在插入數據時,壓縮數據,壓縮之後的數據類型是varbinary(max)

INSERT INTO player (name, surname, info )  
VALUES (N'Ovidiu', N'Cracium', COMPRESS(N'{"sport":"Tennis","age": 28,"rank":1,"points":15258, turn":17}')); 

在查詢數據時,解壓縮數據,將數據從varbinary(max)強轉為原始類型

SELECT _id, name, surname, datemodified, CAST(DECOMPRESS(info) AS NVARCHAR(MAX)) AS info  
FROM player; 

五,調試函數

在TSQL中,使用try 和 catch編寫異常處理代碼,在catch子句中,使用debug函數,能夠獲取異常信息

--返回發生錯誤的代碼行號(LineNumber)
ERROR_LINE ( ) 
--返回錯誤號(ErrorNumber)
ERROR_NUMBER ( ) 
@@ERROR 
--返回錯誤消息(ErrorMessage)
ERROR_MESSAGE ( ) 
--返回發生錯誤的SP Name
ERROR_PROCEDURE ( ) 
--返回錯誤的嚴重度(Error Severity)
ERROR_SEVERITY ( ) 
--返回錯誤的狀態(Error State)
ERROR_STATE() 

在進行調試時,可以以下示例腳本代碼,將異常信息記錄在數據表中,以便進行代碼的故障排除

-- SET XACT_ABORT ON will render the transaction uncommittable when the constraint violation occurs.
SET XACT_ABORT ON;  
  
BEGIN TRY  
    BEGIN TRANSACTION;  
        -- A FOREIGN KEY constraint exists on this table. This statement will generate a constraint violation error.
        DELETE FROM Production.Product  
        WHERE ProductID = 980;  
    -- If the delete operation succeeds, commit the transaction. The CATCH block will not execute.
    COMMIT TRANSACTION;  
END TRY  
BEGIN CATCH  
    -- Test XACT_STATE for 0, 1, or -1.  
    -- If 1, the transaction is committable.  
    -- If -1, the transaction is uncommittable and should be rolled back.
    -- XACT_STATE = 0 means there is no transaction and a commit or rollback operation would generate an error.
  
    -- Test whether the transaction is uncommittable.
    IF (XACT_STATE()) = -1  
    BEGIN  
        --Logging Exception info, as the transaction is in an uncommittable state. Rolling back transaction.
        SELECT  
            ERROR_NUMBER() AS ErrorNumber,  
            ERROR_SEVERITY() AS ErrorSeverity,  
            ERROR_STATE() AS ErrorState,  
            ERROR_PROCEDURE() AS ErrorProcedure,  
            ERROR_LINE() AS ErrorLine,  
            ERROR_MESSAGE() AS ErrorMessage;   
        ROLLBACK TRANSACTION;  
    END;  
    -- Test whether the transaction is active and valid.  
    IF (XACT_STATE()) = 1  
    BEGIN  
        --'The transaction is committable. Committing transaction.'  
        COMMIT TRANSACTION;     
    END;  
END CATCH;  
GO 
View Code

六,DBCC 命令

1,查看資料庫的隔離級別

DBCC USEROPTIONS

 

 

 

 

參考文檔:

Security Functions (Transact-SQL) 

Metadata Functions (Transact-SQL)

Configuration Functions (Transact-SQL)

System Functions (Transact-SQL)


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

-Advertisement-
Play Games
更多相關文章
  • fullpage.js 是一個基於jquery 的插件,它能夠輕鬆的製作出高大上的全屏網站,主要功能有; 1.支持滑鼠滾動 2.支持前進後退和鍵盤控制 3.多個回調函數 4.支持 CSS3 動畫 5.可設置滾動寬度、背景顏色、滾動速度、迴圈選項、回調、文本對齊方式等等。 實現的原理: 1. 視窗大小 ...
  • (未給Fragment的佈局設置BackGound) 之前關於Android中Fragment的概念以及創建方式,我專門寫了一篇博文《Android中Fragment的兩種創建方式》,就如何創建Fragment混合佈局做了詳細的分析,今天就來詳細說道說道Fragment與宿主Activity之間是如 ...
  • 設計思路:給UIView增加一個分類 所有的視圖都可以根據需要來進行紅點顯示 ...
  • 在OC當中自動計算行高主要調用系統的 - (--boundingRectWithSize:(CGSize)size options:(NSStringDrawingOptions)options attributes:(nullable NSDictionary<NSString *, id> *) ...
  • GridView 可以指定顯示的條目的列數。 listview一般顯示的條目的列數都是一列 如果是列表(單列多行形式)的使用ListView,如果是多行多列網狀形式的優先使用GridView android:numColumns=”auto_fit” //GridView的列數設置為自動 GridV ...
  • 現在二維碼的應用越來越普及,二維碼掃描也成為手機應用程式的必備功能了。本文將基於 Xamarin.Android 平臺使用 ZXing.Net.Mobile 做一個簡單的 Android 條碼掃描示常式序。 1、新建一個 Xamarin.Android 應用: 閱讀全文 ...
  • 苦心人天不負, 為了項目終於把 iOS 10 跳轉系統設置的方法給搞定了, 很欣慰. http://www.cnblogs.com/lurenq/p/6189580.html iOS 10 跳轉系統設置的欄位 電池電量 Prefs:root=BATTERY_USAGE 通用設置 Prefs:root ...
  • 從今天開始研究開發自己的編程語言Ocelot,從《自製編譯器》出發,然後再自己不斷完善功能並優化。 編譯器前端簡單,就不深入研究了,直接用現成的一款工具叫JavaCC,它可以生成抽象語法樹,抽象語法樹是生成中間代碼的關鍵,而中間代碼又是生成後端代碼的關鍵。 整個編譯器代碼採用java語言編寫,主要功 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...