TYPEPROPERTY (Transact-SQL)
傳回資料類型的相關資訊。
語法
TYPEPROPERTY (type , property)
引數
type
這是資料類型的名稱。property
這是要針對資料類型傳回的資訊類型。property 可以是下列值之一。屬性
描述
傳回的值
AllowsNull
允許 Null 值的資料類型。
1 = True
0 = False
NULL = 找不到資料類型。
OwnerId
類型的擁有者。
附註結構描述擁有者不一定是類型擁有者。非 Null = 類型擁有者的資料庫使用者識別碼。
NULL = 不支援的類型,或類型識別碼無效。
Precision
資料類型的有效位數。
位數或字元數。
-1 =xml 或大數值資料類型
NULL = 找不到資料類型。
Scale
資料類型的小數位數。
資料類型的小數位數數目。
NULL = 資料類型不是 numeric,或找不到。
UsesAnsiTrim
當建立資料類型時,ANSI 填補設定是 ON。
1 = True
0 = False
NULL = 找不到資料類型,或它不是二進位或字串資料類型。
傳回類型
int
例外狀況
當發生錯誤,或呼叫者沒有檢視物件的權限時,便會傳回 NULL。
在 SQL Server 中,使用者只能檢視使用者擁有或被授與某些權限之安全性實體的中繼資料。這表示發出中繼資料的內建函數 (例如,TYPEPROPERTY) 會在使用者不具有該物件任何權限時傳回 NULL。如需詳細資訊,請參閱<中繼資料可見性組態>和<中繼資料可見性疑難排解>。
範例
A. 識別資料類型的擁有者
下列範例會傳回資料類型的擁有者。
SELECT TYPEPROPERTY(SCHEMA_NAME(schema_id) + '.' + name, 'OwnerId') AS owner_id, name, system_type_id, user_type_id, schema_id
FROM sys.types;
B. 傳回 tinyint 資料類型的有效位數
下列範例會傳回 tinyint 資料類型的有效位數或位數數目。
SELECT TYPEPROPERTY( 'tinyint', 'PRECISION');