首页 >数据库 >mysql教程 >如何以编程方式从 SQL Server 表生成 C# 类?

如何以编程方式从 SQL Server 表生成 C# 类?

Susan Sarandon
Susan Sarandon原创
2024-12-24 08:09:16951浏览

How to Programmatically Generate C# Classes from SQL Server Tables?

如何从 SQL Server 中的数据库表生成类

无需使用即可从 SQL Server 表对象创建简单实体作为类ORM。此方法提供了一种生成与表模式对齐的类结构的简单方法。

步骤:

  1. 设置表名称:声明一个变量@TableName来保存目标表的名称。
  2. 生成类结构: 根据表名以起始括号和类名构造一个字符串 @Result。
  3. 迭代列: 检索列信息(名称、数据类型、可为空性)来自 sys.columns 和 sys.types 系统表,按目标的 object_id 过滤table.
  4. 构建类属性:对于每一列,将类属性声明附加到@Result。属性包括列名、数据类型和可选的可为空字符 (?)(如果列允许空值)。数据类型将转换为 C# 等效项以实现兼容性。
  5. 生成类代码: 使用右括号完成类结构并打印结果代码。这提供了一个镜像指定表架构的 C# 类。

示例:

考虑一个名为“Person”且列为“Name”的表(字符串)和“电话”(可为空字符串):

declare @TableName sysname = 'Person'
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 'varchar' then 'string'
            else 'UNKNOWN_' + typ.name
        end ColumnType,
        case 
            when col.is_nullable = 1 and typ.name = 'varchar' 
            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

输出:

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

以上是如何以编程方式从 SQL Server 表生成 C# 类?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn