Sqlserver
 sql >> डेटाबेस >  >> RDS >> Sqlserver

SQL सर्वर (T-SQL) में डेटा प्रकारों की सूची कैसे लौटाएं

यदि आपको कभी भी SQL सर्वर में डेटा प्रकारों की सूची प्राप्त करने की आवश्यकता होती है, तो आप ऐसा करने के लिए सिस्टम दृश्यों में से किसी एक का उपयोग कर सकते हैं।

विशेष रूप से, आप sys.types . का उपयोग कर सकते हैं सिस्टम कैटलॉग दृश्य। यह दृश्य डेटाबेस में परिभाषित सभी सिस्टम-आपूर्ति और उपयोगकर्ता-परिभाषित डेटा प्रकार देता है। यदि आप SQL Server 2000 का उपयोग कर रहे हैं sys.systypes चाल चलनी चाहिए।

उदाहरण 1 - sys.types देखें

sys.types यदि आप SQL Server 2000 के बाद के SQL सर्वर के संस्करण का उपयोग कर रहे हैं तो view सबसे अच्छा है।

sys.types . का उपयोग करने का सबसे तेज़/आसान तरीका दृश्य सब कुछ चुनना है। उस स्थिति में आपका कोड इस तरह दिख सकता है:

SELECT * FROM sys.types;

हालांकि, यह बहुत सारे कॉलम लौटाता है जिनमें आपकी रुचि हो सकती है या नहीं भी हो सकती है। आप इसे केवल उन कॉलम तक सीमित कर सकते हैं जिनमें आपकी रुचि है।

यहां रुचि के कुछ कॉलम चुनने का एक उदाहरण दिया गया है:

SELECT 
  name,
  max_length,
  [precision],
  scale,
  is_user_defined
FROM sys.types;

परिणाम:

+------------------+--------------+-------------+---------+-------------------+
| name             | max_length   | precision   | scale   | is_user_defined   |
|------------------+--------------+-------------+---------+-------------------|
| image            | 16           | 0           | 0       | 0                 |
| text             | 16           | 0           | 0       | 0                 |
| uniqueidentifier | 16           | 0           | 0       | 0                 |
| date             | 3            | 10          | 0       | 0                 |
| time             | 5            | 16          | 7       | 0                 |
| datetime2        | 8            | 27          | 7       | 0                 |
| datetimeoffset   | 10           | 34          | 7       | 0                 |
| tinyint          | 1            | 3           | 0       | 0                 |
| smallint         | 2            | 5           | 0       | 0                 |
| int              | 4            | 10          | 0       | 0                 |
| smalldatetime    | 4            | 16          | 0       | 0                 |
| real             | 4            | 24          | 0       | 0                 |
| money            | 8            | 19          | 4       | 0                 |
| datetime         | 8            | 23          | 3       | 0                 |
| float            | 8            | 53          | 0       | 0                 |
| sql_variant      | 8016         | 0           | 0       | 0                 |
| ntext            | 16           | 0           | 0       | 0                 |
| bit              | 1            | 1           | 0       | 0                 |
| decimal          | 17           | 38          | 38      | 0                 |
| numeric          | 17           | 38          | 38      | 0                 |
| smallmoney       | 4            | 10          | 4       | 0                 |
| bigint           | 8            | 19          | 0       | 0                 |
| hierarchyid      | 892          | 0           | 0       | 0                 |
| geometry         | -1           | 0           | 0       | 0                 |
| geography        | -1           | 0           | 0       | 0                 |
| varbinary        | 8000         | 0           | 0       | 0                 |
| varchar          | 8000         | 0           | 0       | 0                 |
| binary           | 8000         | 0           | 0       | 0                 |
| char             | 8000         | 0           | 0       | 0                 |
| timestamp        | 8            | 0           | 0       | 0                 |
| nvarchar         | 8000         | 0           | 0       | 0                 |
| nchar            | 8000         | 0           | 0       | 0                 |
| xml              | -1           | 0           | 0       | 0                 |
| sysname          | 256          | 0           | 0       | 0                 |
+------------------+--------------+-------------+---------+-------------------+

ये वर्तमान डेटाबेस के भीतर डेटा प्रकार हैं। यदि आप किसी भिन्न डेटाबेस पर स्विच करते हैं, तो आपको अलग-अलग परिणाम मिल सकते हैं (यह काफी हद तक इस बात पर निर्भर करेगा कि कोई उपयोगकर्ता-परिभाषित डेटा प्रकार या उपनाम डेटा प्रकार परिभाषित किए गए हैं, और वे डेटाबेस के बीच भिन्न हैं या नहीं)।

उदाहरण 2 - उपनाम और उपयोगकर्ता-निर्धारित डेटा प्रकार

पिछले उदाहरण में, मैंने is_user_defined . शामिल किया था कॉलम। हम देख सकते हैं कि कोई भी डेटा प्रकार उपयोगकर्ता-परिभाषित या उपनाम डेटा प्रकार नहीं है, क्योंकि उन सभी में 0 है उनके मूल्य के रूप में।

आइए एक उपनाम डेटा प्रकार बनाएं, और फिर देखें कि यह परिणामों में कैसा दिखाई देता है।

उपनाम डेटा प्रकार बनाएं:

CREATE TYPE SSN  
FROM varchar(11) NOT NULL;

अब क्वेरी को फिर से चलाते हैं।

SELECT 
  name,
  max_length,
  [precision],
  scale,
  is_user_defined
FROM sys.types;

परिणाम:

+------------------+--------------+-------------+---------+-------------------+
| name             | max_length   | precision   | scale   | is_user_defined   |
|------------------+--------------+-------------+---------+-------------------|
| image            | 16           | 0           | 0       | 0                 |
| text             | 16           | 0           | 0       | 0                 |
| uniqueidentifier | 16           | 0           | 0       | 0                 |
| date             | 3            | 10          | 0       | 0                 |
| time             | 5            | 16          | 7       | 0                 |
| datetime2        | 8            | 27          | 7       | 0                 |
| datetimeoffset   | 10           | 34          | 7       | 0                 |
| tinyint          | 1            | 3           | 0       | 0                 |
| smallint         | 2            | 5           | 0       | 0                 |
| int              | 4            | 10          | 0       | 0                 |
| smalldatetime    | 4            | 16          | 0       | 0                 |
| real             | 4            | 24          | 0       | 0                 |
| money            | 8            | 19          | 4       | 0                 |
| datetime         | 8            | 23          | 3       | 0                 |
| float            | 8            | 53          | 0       | 0                 |
| sql_variant      | 8016         | 0           | 0       | 0                 |
| ntext            | 16           | 0           | 0       | 0                 |
| bit              | 1            | 1           | 0       | 0                 |
| decimal          | 17           | 38          | 38      | 0                 |
| numeric          | 17           | 38          | 38      | 0                 |
| smallmoney       | 4            | 10          | 4       | 0                 |
| bigint           | 8            | 19          | 0       | 0                 |
| hierarchyid      | 892          | 0           | 0       | 0                 |
| geometry         | -1           | 0           | 0       | 0                 |
| geography        | -1           | 0           | 0       | 0                 |
| varbinary        | 8000         | 0           | 0       | 0                 |
| varchar          | 8000         | 0           | 0       | 0                 |
| binary           | 8000         | 0           | 0       | 0                 |
| char             | 8000         | 0           | 0       | 0                 |
| timestamp        | 8            | 0           | 0       | 0                 |
| nvarchar         | 8000         | 0           | 0       | 0                 |
| nchar            | 8000         | 0           | 0       | 0                 |
| xml              | -1           | 0           | 0       | 0                 |
| sysname          | 256          | 0           | 0       | 0                 |
| SSN              | 11           | 0           | 0       | 1                 |
+------------------+--------------+-------------+---------+-------------------+

नया डेटा प्रकार प्रकट होता है (सबसे नीचे)। इसका एक मान 1 . भी होता है is_user_defined . में कॉलम।

sys.systypes देखें

एक sys.systypes भी है सिस्टम संगतता दृश्य, जो केवल पश्चगामी संगतता के लिए प्रदान किया जाता है। ऐसा इसलिए है क्योंकि systypes SQL Server 2000 में एक सिस्टम टेबल का नाम था, और उस तालिका को संदर्भित करने वाले कोड के साथ बहुत सारी विरासत प्रणालियाँ हो सकती हैं।

माइक्रोसॉफ्ट ने संकेत दिया है कि sys.systypes सिस्टम संगतता दृश्य Microsoft SQL सर्वर के भविष्य के संस्करण में हटा दिया जाएगा, और इसलिए अनुशंसा करता है कि आप नए कार्य में इस दृश्य का उपयोग करने से बचें।

दूसरे शब्दों में, sys.types . का उपयोग करें इसके बजाय यदि आप।

लेकिन अगर आप अभी भी SQL सर्वर के पुराने संस्करण का उपयोग कर रहे हैं, तो आपको sys.systypes का उपयोग करना होगा ।

ध्यान दें कि sys.systypes sys.types . के लिए अलग-अलग कॉलम/कॉलम नाम शामिल हैं , इसलिए पिछले उदाहरण में मेरे द्वारा उपयोग किए गए कॉलम नाम काम नहीं करेंगे।

आप अभी भी तारक का उपयोग करके सभी स्तंभों का चयन कर सकते हैं (* ) हालांकि वाइल्डकार्ड कैरेक्टर:

SELECT * FROM sys.systypes;

  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL सर्वर में VARCHAR और NVARCHAR में क्या अंतर है - SQL सर्वर / T-SQL ट्यूटोरियल भाग 32

  2. SQL सर्वर डेटाबेस (T-SQL) से डेटा फ़ाइल कैसे निकालें

  3. SQL सर्वर (T-SQL) में डेटाबेस मेल के लिए एक डिफ़ॉल्ट सार्वजनिक प्रोफ़ाइल बनाएँ

  4. WHERE क्लॉज में केस सेंसिटिव सर्च कैसे करें (मैं SQL सर्वर का उपयोग कर रहा हूं)?

  5. अनपेक्षित चर प्रकार प्राप्त-नौकरी द्वारा लौटाया गया