এসকিউএল সার্ভার ক্যোয়ারী ডাটা টাইপের সাথে একটি টেবিলের কলামগুলির তালিকা পেতে, নাল নয়, এবং প্রাথমিক মূল সীমাবদ্ধতাগুলি পেতে


229

নির্দিষ্ট টেবিলের কলামগুলির তালিকা, এর সম্পর্কিত ডেটা ধরণের (দৈর্ঘ্যের সাথে) এবং সেগুলি শূন্য না হলে আমাকে এসকিউএল সার্ভারে একটি প্রশ্ন লিখতে হবে। এবং আমি এটি অনেক কিছু পরিচালনা করেছি।

তবে এখন আমার একই কাতারে একটি কলামের বিপরীতেও থাকা দরকার - TRUEযদি সেই কলামটি প্রাথমিক কী থাকে key

আমি এটা কিভাবে করবো?

আমার প্রত্যাশিত ফলাফল:

Column name | Data type | Length | isnull | Pk

2
আপনি ইতিমধ্যে আপনার কোড প্রদর্শন করতে পারেন?
ডক করুন

উত্তর:


478

কিছু কলামের জন্য নকল সারিগুলি এড়ানোর জন্য system_type_id এর পরিবর্তে user_type_id ব্যবহার করুন।

SELECT 
    c.name 'Column Name',
    t.Name 'Data type',
    c.max_length 'Max Length',
    c.precision ,
    c.scale ,
    c.is_nullable,
    ISNULL(i.is_primary_key, 0) 'Primary Key'
FROM    
    sys.columns c
INNER JOIN 
    sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN 
    sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN 
    sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
    c.object_id = OBJECT_ID('YourTableName')

কেবলমাত্র YourTableNameআপনার আসল সারণীর নাম দিয়ে প্রতিস্থাপন করুন - এসকিউএল সার্ভার 2005 এবং এর জন্য কাজ করে।

যদি আপনি স্কিমের ব্যবহার করছেন, প্রতিস্থাপন YourTableName দ্বারা YourSchemaName.YourTableNameযেখানে YourSchemaNameপ্রকৃত স্কিমা নাম এবং YourTableNameপ্রকৃত টেবিল নাম।


2
এটি এনভারচর ইত্যাদি কলামের ধরণের জন্য ভুল দৈর্ঘ্য দেয়। এটি বাইটের দৈর্ঘ্য দেয় যা কলামের ধরণের দৈর্ঘ্যের দ্বিগুণ।
অ্যান্ড্রু সাবিনিখ

14
এই দৈর্ঘ্যগুলি ভুল নয় - এটি বাইটের দৈর্ঘ্য দেয় - এটি বাইটের মধ্যে সর্বোচ্চ সম্ভাব্য দৈর্ঘ্য ... আপনি যদি স্থান নির্ণয় করতে চান ইত্যাদি ইত্যাদি, আপনি যে দৈর্ঘ্যটি পেতে চান
এটিই

2
এসকিউএল সার্ভার ২০১২ আমার জন্য দুর্দান্ত কাজ করেছে :)
ডক হলিডে

2
WHERE c.object_id = OBJECT_ID ('YourTableName') .... আমার WHOE c.object_id = OBJECT_ID ('MySchema.MyTableName') দরকার ছিল এবং তারপরে সবকিছু ঠিকঠাক কাজ করেছিল।
ইভান

7
যদি আপনার একই কলামটিতে একাধিক সূচী যুক্ত থাকে তবে এই কোয়েরিটি নকল কলামগুলি ফেরত দেয়। এটি ঠিক করতে, শেষের সাথে দুটি যোগ দিয়ে প্রতিস্থাপন করুন: LEFT OUTER JOIN sys.index_columns ic LEFT OUTER JOIN sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id ON ic.object_id = c.object_id AND ic.column_id = c.column_id AND i.is_primary_key=1
রাজন সোকোল

95

সঞ্চিত প্রক্রিয়া এসপি_কলামগুলি বিশদ সারণির তথ্য দেয়।

exec sp_columns MyTable


2
সংক্ষিপ্ত জিজ্ঞাসা কিন্তু বড় কাজ করে।
অক্ষয় চাওলা

1
সুন্দর সংক্ষিপ্ত উত্তর
t_warsop

72

আপনি ক্যোয়ারীটি ব্যবহার করতে পারেন:

select COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, 
       NUMERIC_PRECISION, DATETIME_PRECISION, 
       IS_NULLABLE 
from INFORMATION_SCHEMA.COLUMNS
where TABLE_NAME='TableName'

পিকে তথ্য ব্যতীত আপনার প্রয়োজনীয় সমস্ত মেটাডেটা পেতে।


2
আমি এটা করেছি :) তবে আমার পিকেও দরকার: |
শ্রায়াস


1
এটি দুর্দান্ত কারণ এটি 2005 এর চেয়ে পুরানো এসএস সংস্করণগুলির সাথে কাজ করে Thanks ধন্যবাদ!
কার্ল হোয়াগ্লুন্ড

19

এসকিউএল 2012 এ আপনি ব্যবহার করতে পারেন:

EXEC sp_describe_first_result_set N'SELECT * FROM [TableName]'

এটি আপনাকে তাদের বৈশিষ্ট্য সহ কলামের নাম দেবে give


13

এটা চেষ্টা কর:

select COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, IS_NULLABLE 
from INFORMATION_SCHEMA.COLUMNS IC
where TABLE_NAME = 'tablename' and COLUMN_NAME = 'columnname'

2
আপনার উত্তরটি আজাদেক্সের পোস্টের চেয়ে আলাদা কীভাবে? উভয় উত্তর প্রাথমিক কী তথ্য ফেরত দেয় না।
আর্টেমিক্স

10

সঠিক দৈর্ঘ্যটি নিশ্চিত করার জন্য আপনাকে ইউনিকোডের ধরণগুলি একটি বিশেষ কেস হিসাবে বিবেচনা করতে হবে। নীচে কোড দেখুন।

আরও তথ্যের জন্য দেখুন: https://msdn.microsoft.com/en-us/library/ms176106.aspx

SELECT 
   c.name 'Column Name',
   t.name,
   t.name +
   CASE WHEN t.name IN ('char', 'varchar','nchar','nvarchar') THEN '('+

             CASE WHEN c.max_length=-1 THEN 'MAX'

                  ELSE CONVERT(VARCHAR(4),

                               CASE WHEN t.name IN ('nchar','nvarchar')

                               THEN  c.max_length/2 ELSE c.max_length END )

                  END +')'

          WHEN t.name IN ('decimal','numeric')

                  THEN '('+ CONVERT(VARCHAR(4),c.precision)+','

                          + CONVERT(VARCHAR(4),c.Scale)+')'

                  ELSE '' END

   as "DDL name",
   c.max_length 'Max Length in Bytes',
   c.precision ,
   c.scale ,
   c.is_nullable,
   ISNULL(i.is_primary_key, 0) 'Primary Key'
FROM    
   sys.columns c
INNER JOIN 
   sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN 
   sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN 
   sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
   c.object_id = OBJECT_ID('YourTableName')

1
ডিডিএল নামটি ডায়নামিক-এসকিএল-তে টেবিল তৈরির জন্য কার্যকর! ধন্যবাদ !!
জর্জ মেনআটিস

6

অ্যালেক্সের উত্তরটি প্রসারিত করে, আপনি পিকে সীমাবদ্ধতা পেতে এটি করতে পারেন

Select C.COLUMN_NAME, C.DATA_TYPE, C.CHARACTER_MAXIMUM_LENGTH, C.NUMERIC_PRECISION, C.IS_NULLABLE, TC.CONSTRAINT_NAME
From INFORMATION_SCHEMA.COLUMNS As C
    Left Join INFORMATION_SCHEMA.TABLE_CONSTRAINTS As TC
      On TC.TABLE_SCHEMA = C.TABLE_SCHEMA
          And TC.TABLE_NAME = C.TABLE_NAME
          And TC.CONSTRAINT_TYPE = 'PRIMARY KEY'
Where C.TABLE_NAME = 'Table'

আমি অবশ্যই মিস করেছি যে আপনি প্রদত্ত কলামটি পিকে সীমাবদ্ধতার নামের পরিবর্তে পিকে-র অংশ ছিল কিনা তা নির্ধারণ করার জন্য আপনি একটি পতাকা চান। তার জন্য আপনি ব্যবহার করবেন:

Select C.COLUMN_NAME, C.DATA_TYPE, C.CHARACTER_MAXIMUM_LENGTH
    , C.NUMERIC_PRECISION, C.NUMERIC_SCALE
    , C.IS_NULLABLE
    , Case When Z.CONSTRAINT_NAME Is Null Then 0 Else 1 End As IsPartOfPrimaryKey
From INFORMATION_SCHEMA.COLUMNS As C
    Outer Apply (
                Select CCU.CONSTRAINT_NAME
                From INFORMATION_SCHEMA.TABLE_CONSTRAINTS As TC
                    Join INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE As CCU
                        On CCU.CONSTRAINT_NAME = TC.CONSTRAINT_NAME
                Where TC.TABLE_SCHEMA = C.TABLE_SCHEMA
                    And TC.TABLE_NAME = C.TABLE_NAME
                    And TC.CONSTRAINT_TYPE = 'PRIMARY KEY'
                    And CCU.COLUMN_NAME = C.COLUMN_NAME
                ) As Z
Where C.TABLE_NAME = 'Table'

আমরা হব. এটি আমাকে প্রয়োজনীয় ফলাফল দেয় না :(
শ্রায়াস

5

স্বেচ্ছাসেবীর টেবিলের নামটি কোয়েরি সম্পাদকের নামটি নির্বাচন করুন এবং Alt + F1 টিপুন এবং এটি টেবিলের সমস্ত তথ্য নিয়ে আসবে।


তিনি একটি জিজ্ঞাসা চাইছেন, তবে আপনি ঠিক এই পথে আপনাকে সমস্ত তথ্য দেখতে দেয়।
রাফা ব্যারাগান

কিন্তু এখনো; সুপার ঝরঝরে :-)

4
SELECT COLUMN_NAME, IS_NULLABLE, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH FROM information_schema.columns WHERE table_name = '<name_of_table_or_view>'

তথ্য_সেমি.কলামগুলি SELECT *কী ফিরিয়ে দেয় তা দেখতে উপরের বিবৃতিতে চালান ।

এই প্রশ্নের পূর্বে উত্তর দেওয়া হয়েছে - https://stackoverflow.com/a/11268456/6169225


যদি এই প্রশ্নের ইতিমধ্যে উত্তর দেওয়া হয়ে থাকে, তবে নকল হিসাবে পোস্টটিকে ফ্ল্যাগ করুন
মার্টিজন পিটারস


3
IF EXISTS (SELECT 1 FROM INFORMATION_SCHEMA.TABLES 
     WHERE TABLE_TYPE = 'BASE TABLE' AND TABLE_NAME = 'Table')
      BEGIN
        SELECT COLS.COLUMN_NAME, COLS.DATA_TYPE, COLS.CHARACTER_MAXIMUM_LENGTH, 
              (SELECT 'Yes' FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS TC JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE KCU
                              ON COLS.TABLE_NAME = TC.TABLE_NAME 
                             AND TC.CONSTRAINT_TYPE = 'PRIMARY KEY'
                             AND KCU.TABLE_NAME = TC.TABLE_NAME
                             AND KCU.CONSTRAINT_NAME = TC.CONSTRAINT_NAME
                             AND KCU.COLUMN_NAME = COLS.COLUMN_NAME) AS KeyX
        FROM INFORMATION_SCHEMA.COLUMNS COLS WHERE TABLE_NAME = 'Table' ORDER BY KeyX DESC, COLUMN_NAME
      END

3

রিংয়ের মধ্যে আরও একটি উত্তর ছুঁড়ে দেওয়া, এটি আপনাকে সেই কলামগুলি এবং আরও অনেক কিছু দেবে:

SELECT col.TABLE_CATALOG AS [Database]
     , col.TABLE_SCHEMA AS Owner
     , col.TABLE_NAME AS TableName
     , col.COLUMN_NAME AS ColumnName
     , col.ORDINAL_POSITION AS OrdinalPosition
     , col.COLUMN_DEFAULT AS DefaultSetting
     , col.DATA_TYPE AS DataType
     , col.CHARACTER_MAXIMUM_LENGTH AS MaxLength
     , col.DATETIME_PRECISION AS DatePrecision
     , CAST(CASE col.IS_NULLABLE
                WHEN 'NO' THEN 0
                ELSE 1
            END AS bit)AS IsNullable
     , COLUMNPROPERTY(OBJECT_ID('[' + col.TABLE_SCHEMA + '].[' + col.TABLE_NAME + ']'), col.COLUMN_NAME, 'IsIdentity')AS IsIdentity
     , COLUMNPROPERTY(OBJECT_ID('[' + col.TABLE_SCHEMA + '].[' + col.TABLE_NAME + ']'), col.COLUMN_NAME, 'IsComputed')AS IsComputed
     , CAST(ISNULL(pk.is_primary_key, 0)AS bit)AS IsPrimaryKey
  FROM INFORMATION_SCHEMA.COLUMNS AS col
       LEFT JOIN(SELECT SCHEMA_NAME(o.schema_id)AS TABLE_SCHEMA
                      , o.name AS TABLE_NAME
                      , c.name AS COLUMN_NAME
                      , i.is_primary_key
                   FROM sys.indexes AS i JOIN sys.index_columns AS ic ON i.object_id = ic.object_id
                                                                     AND i.index_id = ic.index_id
                                         JOIN sys.objects AS o ON i.object_id = o.object_id
                                         LEFT JOIN sys.columns AS c ON ic.object_id = c.object_id
                                                                   AND c.column_id = ic.column_id
                  WHERE i.is_primary_key = 1)AS pk ON col.TABLE_NAME = pk.TABLE_NAME
                                                  AND col.TABLE_SCHEMA = pk.TABLE_SCHEMA
                                                  AND col.COLUMN_NAME = pk.COLUMN_NAME
 WHERE col.TABLE_NAME = 'YourTableName'
   AND col.TABLE_SCHEMA = 'dbo'
 ORDER BY col.TABLE_NAME, col.ORDINAL_POSITION;

2
select
      c.name as [column name], 
      t.name as [type name],
      tbl.name as [table name]
from sys.columns c
         inner join sys.types t 
      on c.system_type_id = t.system_type_id 
         inner join sys.tables tbl
      on c.object_id = tbl.object_id
where
      c.object_id = OBJECT_ID('YourTableName1') 
          and 
      t.name like '%YourSearchDataType%'
union
(select
      c.name as [column name], 
      t.name as [type name],
      tbl.name as [table name]
from sys.columns c
         inner join sys.types t 
      on c.system_type_id = t.system_type_id 
         inner join sys.tables tbl
      on c.object_id = tbl.object_id
where
      c.object_id = OBJECT_ID('YourTableName2') 
          and 
      t.name like '%YourSearchDataType%')
union
(select
      c.name as [column name], 
      t.name as [type name],
      tbl.name as [table name]
from sys.columns c
         inner join sys.types t 
      on c.system_type_id = t.system_type_id 
         inner join sys.tables tbl
      on c.object_id = tbl.object_id
where
      c.object_id = OBJECT_ID('YourTableName3') 
          and 
      t.name like '%YourSearchDataType%')
order by tbl.name

আপনার সন্ধানের ডেটা ভিত্তিতে কোন কলামে কোন কলাম রয়েছে তা অনুসন্ধান করতে একটি ডাটাবেসে তিনটি পৃথক টেবিলের জন্য টাইপ করুন। এই কোয়েরিটি 'এন' টেবিলগুলিতে প্রসারিত।


2

ডেটাটাইপ এবং দৈর্ঘ্যের জন্য সম্মিলিত ফলাফল সন্ধান করুন এবং "NULL" এবং "নাল নট নয়" আকারে অণনীয় এবং প্রশ্নের নীচে ব্যবহার করুন।

SELECT c.name AS 'Column Name',
       t.name + '(' + cast(c.max_length as varchar(50)) + ')' As 'DataType',
       case 
         WHEN  c.is_nullable = 0 then 'null' else 'not null'
         END AS 'Constraint'
  FROM sys.columns c
  JOIN sys.types t
    ON c.user_type_id = t.user_type_id
 WHERE c.object_id    = Object_id('TableName')

নীচে প্রদর্শিত হিসাবে আপনি ফলাফল পাবেন।

এখানে চিত্র বর্ণনা লিখুন

ধন্যবাদ.


1
আপনার প্রতিবন্ধকতার অবস্থা অন্যভাবে হওয়া উচিত।
অ্যালেন

0
SELECT  
   T.NAME AS [TABLE NAME]
   ,C.NAME AS [COLUMN NAME]
   ,P.NAME AS [DATA TYPE]
   ,P.MAX_LENGTH AS [Max_SIZE]
   ,C.[max_length] AS [ActualSizeUsed]
   ,CAST(P.PRECISION AS VARCHAR) +'/'+ CAST(P.SCALE AS VARCHAR) AS [PRECISION/SCALE]
FROM SYS.OBJECTS AS T
JOIN SYS.COLUMNS AS C
    ON T.OBJECT_ID = C.OBJECT_ID
JOIN SYS.TYPES AS P
    ON C.SYSTEM_TYPE_ID = P.SYSTEM_TYPE_ID
    AND C.[user_type_id] = P.[user_type_id]
WHERE T.TYPE_DESC='USER_TABLE'
  AND T.name = 'InventoryStatus'
ORDER BY 2

1
দয়া করে ইনলাইন মার্কআপের পরিবর্তে ইনডেন্টেশন ব্যবহার করুন এবং আপনার উত্তরে কিছু ব্যাখ্যা যুক্ত করুন।
টক্সেন্ট্রন

কেন অর্ডার 2?
রেগেইগুইটার

0

এখানে চিত্র বর্ণনা লিখুন

অনুসন্ধান: EXEC SP_DESCRIBE_FIRST_RE صلاح T_SET [BSLID2C] এর পক্ষ থেকে আনুয়াল নাম্বার আটকান [[ডিবিও] [

দ্রষ্টব্য: কিছু আইডিতে এন নির্বাচন করছেন এর আগে এন কাজ করছে বা, কিছু আইডিতে এন কাজ করছে না


0

এখানে কোনও প্রাথমিক কী নেই, তবে এটি এমন অন্যান্য ব্যবহারকারীদের সহায়তা করতে পারে যারা কেবলমাত্র ক্ষেত্রের নাম এবং মৌলিক ক্ষেত্রের বৈশিষ্ট্য সহ একটি টেবিলের নাম রাখতে চান

USE [**YourDB**]
GO
SELECT tbl.name, fld.[Column Name],fld.[Constraint],fld.DataType 
FROM sys.all_objects as tbl left join 
(SELECT c.OBJECT_ID,  c.name AS 'Column Name',
       t.name + '(' + cast(c.max_length as varchar(50)) + ')' As 'DataType',
       case 
         WHEN  c.is_nullable = 0 then 'null' else 'not null'
         END AS 'Constraint'
  FROM sys.columns c
  JOIN sys.types t
    ON c.user_type_id = t.user_type_id
) as fld on tbl.OBJECT_ID = fld.OBJECT_ID
WHERE ( tbl.[type]='U' and tbl.[is_ms_shipped] = 0)
ORDER BY tbl.[name],fld.[Column Name]
GO

-1

আমি সবেমাত্র marc_s "উপস্থাপনা প্রস্তুত" করেছি:

SELECT 
    c.name 'Column Name',
    t.name 'Data type',
    IIF(t.name = 'nvarchar', c.max_length / 2, c.max_length) 'Max Length',
    c.precision 'Precision',
    c.scale 'Scale',
    IIF(c.is_nullable = 0, 'No', 'Yes') 'Nullable',
    IIF(ISNULL(i.is_primary_key, 0) = 0, 'No', 'Yes') 'Primary Key'
FROM    
    sys.columns c
INNER JOIN 
    sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN 
    sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN 
    sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
    c.object_id = OBJECT_ID('YourTableName')
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.