DoenaSoft.SqlServerDatabaseMeta
1.1.1
.NET 6.0
This package targets .NET 6.0. The package is compatible with this framework or higher.
.NET Framework 4.7.2
This package targets .NET Framework 4.7.2. The package is compatible with this framework or higher.
dotnet add package DoenaSoft.SqlServerDatabaseMeta --version 1.1.1
NuGet\Install-Package DoenaSoft.SqlServerDatabaseMeta -Version 1.1.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="DoenaSoft.SqlServerDatabaseMeta" Version="1.1.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add DoenaSoft.SqlServerDatabaseMeta --version 1.1.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: DoenaSoft.SqlServerDatabaseMeta, 1.1.1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install DoenaSoft.SqlServerDatabaseMeta as a Cake Addin #addin nuget:?package=DoenaSoft.SqlServerDatabaseMeta&version=1.1.1 // Install DoenaSoft.SqlServerDatabaseMeta as a Cake Tool #tool nuget:?package=DoenaSoft.SqlServerDatabaseMeta&version=1.1.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
SQL Server Database Meta
This package allows the read-only access to the meta data of a SQL Server database.
It reads out table structures and their columns, the same for views.
It reads out primary and foreign key constraints and establishes linkes between meta tables according to these foreign keys.
It reads out field constraints and checks.
Tables and Views Query
SELECT TableName,
Type,
Description
FROM
(
SELECT t.name AS TableName,
'BASE TABLE' AS Type,
CAST(ep.value AS varchar) AS Description
FROM sys.tables AS t
LEFT OUTER JOIN sys.extended_properties AS ep
ON t.object_id = ep.major_id
AND ep.minor_id = 0
AND ep.name = 'MS_Description'
UNION
SELECT v.name AS TableName,
'VIEW' AS Type,
CAST(ep.value AS varchar) AS Description
FROM sys.views AS v
LEFT OUTER JOIN sys.extended_properties AS ep
ON v.object_id = ep.major_id
AND ep.minor_id = 0
AND ep.name = 'MS_Description'
) AS Tables
Columms Query
select table_name as TableName,
Column_name as ColumnName,
ordinal_position as ColumnIndex,
column_default as DefaultValue,
CASE
WHEN SchemaCol.IS_NULLABLE = 'YES' THEN
1
WHEN SchemaCol.IS_NULLABLE = 'NO' THEN
0
ELSE
NULL
END AS IsNullable,
Data_type as DataType,
numeric_precision as NumericPrecision,
numeric_scale as NumericScale,
Character_Maximum_length as MaxTextLength,
collation_name as TextCollation,
itab.IsIdentity as IsIdentity,
itab.Description as Description,
itab.ColumnId
from INFORMATION_SCHEMA.COLUMNS SchemaCol
left outer join
(
select tab.name as TableName,
col.name as ColumnName,
col.is_identity as IsIdentity,
col.is_nullable as IsNullable,
cast(ep.value as varchar) as Description,
col.column_id as ColumnId
from sys.columns col
inner join sys.tables tab
on col.object_id = tab.object_id
left outer join sys.extended_properties ep
on col.object_id = ep.major_id
and col.column_id = ep.minor_id
and ep.name = 'MS_Description'
where tab.type = 'U'
) itab
on SchemaCol.TABLE_NAME = itab.TableName
and SchemaCol.COLUMN_NAME = itab.ColumnName
order by TableName,
ColumnIndex
Foreign Keys Query
SELECT f.name as ForeignKeyName,
OBJECT_NAME(f.parent_object_id) SourceTableName,
COL_NAME(fc.parent_object_id, fc.parent_column_id) as ColumName,
OBJECT_NAME(f.referenced_object_id) as TargetTableName,
f.key_index_id as TargetTableIndexId,
fc.parent_column_id as SourceColumnIndex,
fc.referenced_column_id as TargetColumnIndex,
cast(ep.value as varchar) as Description
FROM sys.foreign_keys AS f
INNER JOIN sys.foreign_key_columns AS fc
ON f.OBJECT_ID = fc.constraint_object_id
left outer join sys.extended_properties ep
on f.object_id = ep.major_id
and ep.name = 'MS_Description'
INNER JOIN sys.tables t
ON t.OBJECT_ID = fc.referenced_object_id
order by SourceTableName,
TargetTableName,
SourceColumnIndex
Indices (Indexes) Query
SELECT o.NAME AS 'TableName',
i.NAME AS 'IndexName',
LOWER(i.type_desc) + CASE
WHEN i.is_unique = 1 THEN
', unique'
ELSE
''
END + CASE
WHEN i.is_primary_key = 1 THEN
', primary key'
ELSE
''
END AS 'Properties',
STUFF(
(
SELECT ', ' + sc.NAME AS "text()"
FROM syscolumns AS sc
INNER JOIN sys.index_columns AS ic
ON ic.object_id = sc.id
AND ic.column_id = sc.colid
WHERE sc.id = so.object_id
AND ic.index_id = i1.indid
AND ic.is_included_column = 0
ORDER BY key_ordinal
FOR XML PATH('')
),
1,
2,
''
) AS 'Columns',
i.index_id as IndexId,
cast(ep.value as varchar) as Description
FROM sysindexes AS i1
INNER JOIN sys.indexes AS i
ON i.object_id = i1.id
AND i.index_id = i1.indid
INNER JOIN sysobjects AS o
ON o.id = i1.id
INNER JOIN sys.objects AS so
ON so.object_id = o.id
AND is_ms_shipped = 0
INNER JOIN sys.schemas AS s
ON s.schema_id = so.schema_id
left outer join sys.objects so1
on i.object_id = so1.parent_object_id
and i.name = so1.name
left outer join sys.extended_properties ep
on so1.object_id = ep.major_id
and ep.name = 'MS_Description'
WHERE so.type = 'U'
AND i1.indid < 255
AND i1.STATUS & 64 = 0 --index with duplicates
AND i1.STATUS & 8388608 = 0 --auto created index
AND i1.STATUS & 16777216 = 0 --stats no recompute
AND i.type_desc <> 'heap'
AND so.NAME <> 'sysdiagrams'
Order by TableName,
IndexId
Checks Query
select cc.name as CheckName,
t.name as TableName,
cc.Definition,
cast(ep.value as varchar) as Description
from sys.check_constraints cc
inner join sys.tables t
on cc.parent_object_id = t.object_id
left outer join sys.extended_properties ep
on cc.object_id = ep.major_id
and ep.name = 'MS_Description'
where t.type = 'U'
order by TableName,
CheckName
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Framework | net472 is compatible. net48 was computed. net481 was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETFramework 4.7.2
- System.Data.DataSetExtensions (>= 4.5.0)
- System.Data.SqlClient (>= 4.8.6)
-
net6.0
- System.Data.DataSetExtensions (>= 4.5.0)
- System.Data.SqlClient (>= 4.8.6)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.