Heim >Datenbank >MySQL-Tutorial >Wie generiert man C#-Klassen aus SQL Server-Tabellen ohne ORM?

Wie generiert man C#-Klassen aus SQL Server-Tabellen ohne ORM?

Susan Sarandon
Susan SarandonOriginal
2024-12-21 02:46:09452Durchsuche

How to Generate C# Classes from SQL Server Tables Without an ORM?

Klassen aus SQL Server-Tabellenobjekten generieren

Problem:
Wie können Sie einfache Klassen generieren, die darstellen die Entitäten in einer SQL Server-Tabelle, ohne eine zu verwenden ORM?

Lösung:
Das folgende SQL-Skript kann verwendet werden, um eine Klassendefinition für eine bestimmte Tabelle zu generieren:

declare @TableName sysname = 'TableName';
declare @Result varchar(max) = 'public class ' + @TableName + ' {';

select @Result = @Result + '
    public ' + ColumnType + NullableSign + ' ' + ColumnName + ' { get; set; }
'
from
(
    select 
        replace(col.name, ' ', '_') ColumnName,
        column_id ColumnId,
        case typ.name 
            when 'bigint' then 'long'
            when 'binary' then 'byte[]'
            when 'bit' then 'bool'
            when 'char' then 'string'
            when 'date' then 'DateTime'
            when 'datetime' then 'DateTime'
            when 'datetime2' then 'DateTime'
            when 'datetimeoffset' then 'DateTimeOffset'
            when 'decimal' then 'decimal'
            when 'float' then 'double'
            when 'image' then 'byte[]'
            when 'int' then 'int'
            when 'money' then 'decimal'
            when 'nchar' then 'string'
            when 'ntext' then 'string'
            when 'numeric' then 'decimal'
            when 'nvarchar' then 'string'
            when 'real' then 'float'
            when 'smalldatetime' then 'DateTime'
            when 'smallint' then 'short'
            when 'smallmoney' then 'decimal'
            when 'text' then 'string'
            when 'time' then 'TimeSpan'
            when 'timestamp' then 'long'
            when 'tinyint' then 'byte'
            when 'uniqueidentifier' then 'Guid'
            when 'varbinary' then 'byte[]'
            when 'varchar' then 'string'
            else 'UNKNOWN_' + typ.name
        end ColumnType,
        case 
            when col.is_nullable = 1 and typ.name in ('bigint', 'bit', 'date', 'datetime', 'datetime2', 'datetimeoffset', 'decimal', 'float', 'int', 'money', 'numeric', 'real', 'smalldatetime', 'smallint', 'smallmoney', 'time', 'tinyint', 'uniqueidentifier') 
            then '?' 
            else '' 
        end NullableSign
    from sys.columns col
        join sys.types typ on
            col.system_type_id = typ.system_type_id AND col.user_type_id = typ.user_type_id
    where object_id = object_id(@TableName)
) t
order by ColumnId;

set @Result = @Result + '
}';

print @Result;

Beispiel:
Für eine Tabelle namens „Person“ mit den Spalten „Name“ und „Telefon“ wäre die generierte Klasse:

public class Person
{
    public string Name { get; set; }
    public string Phone { get; set; }
}

Das obige ist der detaillierte Inhalt vonWie generiert man C#-Klassen aus SQL Server-Tabellen ohne ORM?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn