SQL Server 쿼리에 테이블 구조를 표시하려면 어떻게 해야 합니까?
SELECT DateTime, Skill, Name, TimeZone, ID, User, Employee, Leader
FROM t_Agent_Skill_Group_Half_Hour AS t
쿼리에서 테이블 구조를 확인해야 합니다.
SQL Server의 경우 최신 버전을 사용하는 경우
select *
from INFORMATION_SCHEMA.COLUMNS
where TABLE_NAME='tableName'
스키마를 취득하는 방법은 다양합니다.ADO 사용.NET 스키마 메서드를 사용할 수 있습니다.를 사용합니다.DbConnection
의 메서드 또는DataReader
의GetSchemaTable
메서드입니다.
쿼리용 리더가 있는 경우 다음과 같은 작업을 수행할 수 있습니다.
using(DbCommand cmd = ...)
using(var reader = cmd.ExecuteReader())
{
var schema = reader.GetSchemaTable();
foreach(DataRow row in schema.Rows)
{
Debug.WriteLine(row["ColumnName"] + " - " + row["DataTypeName"])
}
}
sp_help tablename
sql 서버에서
desc tablename
신탁으로
다음 쿼리를 사용해 보십시오.
DECLARE @table_name SYSNAME
SELECT @table_name = 'dbo.test_table'
DECLARE
@object_name SYSNAME
, @object_id INT
SELECT
@object_name = '[' + s.name + '].[' + o.name + ']'
, @object_id = o.[object_id]
FROM sys.objects o WITH (NOWAIT)
JOIN sys.schemas s WITH (NOWAIT) ON o.[schema_id] = s.[schema_id]
WHERE s.name + '.' + o.name = @table_name
AND o.[type] = 'U'
AND o.is_ms_shipped = 0
DECLARE @SQL NVARCHAR(MAX) = ''
;WITH index_column AS
(
SELECT
ic.[object_id]
, ic.index_id
, ic.is_descending_key
, ic.is_included_column
, c.name
FROM sys.index_columns ic WITH (NOWAIT)
JOIN sys.columns c WITH (NOWAIT) ON ic.[object_id] = c.[object_id] AND ic.column_id = c.column_id
WHERE ic.[object_id] = @object_id
)
SELECT @SQL = 'CREATE TABLE ' + @object_name + CHAR(13) + '(' + CHAR(13) + STUFF((
SELECT CHAR(9) + ', [' + c.name + '] ' +
CASE WHEN c.is_computed = 1
THEN 'AS ' + cc.[definition]
ELSE UPPER(tp.name) +
CASE WHEN tp.name IN ('varchar', 'char', 'varbinary', 'binary', 'text')
THEN '(' + CASE WHEN c.max_length = -1 THEN 'MAX' ELSE CAST(c.max_length AS VARCHAR(5)) END + ')'
WHEN tp.name IN ('nvarchar', 'nchar', 'ntext')
THEN '(' + CASE WHEN c.max_length = -1 THEN 'MAX' ELSE CAST(c.max_length / 2 AS VARCHAR(5)) END + ')'
WHEN tp.name IN ('datetime2', 'time2', 'datetimeoffset')
THEN '(' + CAST(c.scale AS VARCHAR(5)) + ')'
WHEN tp.name = 'decimal'
THEN '(' + CAST(c.[precision] AS VARCHAR(5)) + ',' + CAST(c.scale AS VARCHAR(5)) + ')'
ELSE ''
END +
CASE WHEN c.collation_name IS NOT NULL THEN ' COLLATE ' + c.collation_name ELSE '' END +
CASE WHEN c.is_nullable = 1 THEN ' NULL' ELSE ' NOT NULL' END +
CASE WHEN dc.[definition] IS NOT NULL THEN ' DEFAULT' + dc.[definition] ELSE '' END +
CASE WHEN ic.is_identity = 1 THEN ' IDENTITY(' + CAST(ISNULL(ic.seed_value, '0') AS CHAR(1)) + ',' + CAST(ISNULL(ic.increment_value, '1') AS CHAR(1)) + ')' ELSE '' END
END + CHAR(13)
FROM sys.columns c WITH (NOWAIT)
JOIN sys.types tp WITH (NOWAIT) ON c.user_type_id = tp.user_type_id
LEFT JOIN sys.computed_columns cc WITH (NOWAIT) ON c.[object_id] = cc.[object_id] AND c.column_id = cc.column_id
LEFT JOIN sys.default_constraints dc WITH (NOWAIT) ON c.default_object_id != 0 AND c.[object_id] = dc.parent_object_id AND c.column_id = dc.parent_column_id
LEFT JOIN sys.identity_columns ic WITH (NOWAIT) ON c.is_identity = 1 AND c.[object_id] = ic.[object_id] AND c.column_id = ic.column_id
WHERE c.[object_id] = @object_id
ORDER BY c.column_id
FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'), 1, 2, CHAR(9) + ' ')
+ ISNULL((SELECT CHAR(9) + ', CONSTRAINT [' + k.name + '] PRIMARY KEY (' +
(SELECT STUFF((
SELECT ', [' + c.name + '] ' + CASE WHEN ic.is_descending_key = 1 THEN 'DESC' ELSE 'ASC' END
FROM sys.index_columns ic WITH (NOWAIT)
JOIN sys.columns c WITH (NOWAIT) ON c.[object_id] = ic.[object_id] AND c.column_id = ic.column_id
WHERE ic.is_included_column = 0
AND ic.[object_id] = k.parent_object_id
AND ic.index_id = k.unique_index_id
FOR XML PATH(N''), TYPE).value('.', 'NVARCHAR(MAX)'), 1, 2, ''))
+ ')' + CHAR(13)
FROM sys.key_constraints k WITH (NOWAIT)
WHERE k.parent_object_id = @object_id
AND k.[type] = 'PK'), '') + ')' + CHAR(13)
PRINT @SQL
출력:
CREATE TABLE [dbo].[test_table]
(
[WorkOutID] BIGINT NOT NULL IDENTITY(1,1)
, [DateOut] DATETIME NOT NULL
, [EmployeeID] INT NOT NULL
, [IsMainWorkPlace] BIT NOT NULL DEFAULT((1))
, [WorkPlaceUID] UNIQUEIDENTIFIER NULL
, [WorkShiftCD] NVARCHAR(10) COLLATE Cyrillic_General_CI_AS NULL
, [CategoryID] INT NULL
, CONSTRAINT [PK_WorkOut] PRIMARY KEY ([WorkOutID] ASC)
)
다음 내용도 읽어주세요.
SQL 서버 2012에서는 다음 저장 프로시저를 사용할 수 있습니다.
sp_columns '<table name>'
예를 들어 users라는 이름의 데이터베이스 테이블을 지정하면 다음과 같습니다.
sp_columns 'users'
SQL Server에서는 다음 쿼리를 사용할 수 있습니다.
USE Database_name
SELECT *
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME='Table_Name';
교환하는 것을 잊지 마세요.Database_name
그리고.Table_name
데이터베이스 이름과 테이블 이름을 정확하게 입력합니다.
SQL Server Management Studio 최신 버전의 경우 쿼리 에디터에 를 쓰고 "Alt" + "F1"을 수행합니다.
다음 쿼리를 사용해 보십시오.
select *
from (SELECT TABLE_SCHEMA
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME='brands')[.brands];
스키마를 인쇄하려면 옥을 사용하여 데이터베이스의 파일로 내보낸 후 워드 형식으로 가져와 포맷하고 인쇄합니다.
'DESC table_name'을 사용하려고 했는데 psql에서는 이 방법이 효과가 있었습니다.
select *
from INFORMATION_SCHEMA.COLUMNS
where TABLE_NAME='table_name';
또 다른 방법은
mysql > SHOW CREATE TABLE my_db.my_table;
테이블 이름을 가져와 테이블 sql을 생성해야 합니다.
언급URL : https://stackoverflow.com/questions/18298433/how-can-i-show-the-table-structure-in-sql-server-query
'programing' 카테고리의 다른 글
다른 cmd.exe 프롬프트에서 새 cmd.exe 창을 만듭니다. (0) | 2023.04.14 |
---|---|
텍스트 영역의 크기 조정 가능한 속성을 비활성화하려면 어떻게 해야 합니까? (0) | 2023.04.09 |
wpf에서 창 내 요소의 절대 위치를 가져옵니다. (0) | 2023.04.09 |
node.js를 Windows에서 완전히 삭제하는 방법 (0) | 2023.04.09 |
Swift 컴파일 시간이 왜 이렇게 느리죠? (0) | 2023.04.09 |