EF将数据库转成实体对象_没有注释的问题

这里分成2个部分

  1. 从数据库到edmx(模型设计器)
  2. 从edmx到cs文件(tt模版生成)

网络上找到比较多的教程,都是第二步的。

  1. 在edmx中,修改属性→摘要。
    在这里插入图片描述
  2. 在t4模版中(后缀名tt)中,将摘要转成注释
    t4模版的具体语法和调试方法,可以自行百度,这里大概介绍一下修改的位置和原因,下面是具体的操作
    1.搜索foreach (var entity in typeMapper.GetItemsToGenerate(itemCollection))
    这是模版的开头,看这和cs类似的语法,将整个模型通过foreach,遍历出不同的实体(不同的表)
    在foreach的上面,添加一个变量:
string summary=string.Empty;

在foreach里面,将表的注释取出来

if(entity.Documentation !=null && entity.Documentation.Summary!=null)
		summary=entity.Documentation.Summary;
    else
		summary="";

后续在

<#=codeStringGenerator.UsingDirectives(inHeader: false)#>
<#=codeStringGenerator.EntityClassOpening(entity)#>

的中间,加入注释
///
/// <#=summary#>
///
那么,完整的代码如下:

string summary=string.Empty;
foreach (var entity in typeMapper.GetItemsToGenerate<EntityType>(itemCollection))
{
    fileManager.StartNewFile(entity.Name + ".cs");
    BeginNamespace(code);
	if(entity.Documentation !=null && entity.Documentation.Summary!=null)
		summary=entity.Documentation.Summary;
    else
		summary="这个表没有摘要(注释)";
#>
<#=codeStringGenerator.UsingDirectives(inHeader: false)#>
/// <summary>
/// <#=summary#>
/// </summary>
<#=codeStringGenerator.EntityClassOpening(entity)#>

这里是类的注释,后续属性的注释也是一样的
找到

foreach (var edmProperty in simpleProperties)

这个是属性的循环生成,注释也在这里面写
添加一个属性的摘要获取:

if (edmProperty.Documentation != null && edmProperty.Documentation.Summary != null)
{
	summary=edmProperty.Documentation.Summary;
}
else
{
	summary="没有属性注释";
}

然后在

<#=codeStringGenerator.Property(edmProperty)#>

的上面添加注释,完整代码如下:

foreach (var edmProperty in simpleProperties)
        {
			if (edmProperty.Documentation != null && edmProperty.Documentation.Summary != null)
			{
				summary=edmProperty.Documentation.Summary;
			}
			else
			{
				summary="没有属性注释";
			}
#>
	/// <summary>
	/// <#=summary#>
	/// </summary>
    <#=codeStringGenerator.Property(edmProperty)#>

没有摘要,直接从数据库中获取字段注释

上面是从摘要到实体的注释过程。
可是,明明数据库中已经写好了注释,这里如果在模版里再写一遍,总感觉太麻烦。
那么在上面的方法中,可以做一步扩展,那就是,直接从数据库中获取注释。
具体代码如下:
写一个获取字段注释的类,根据t4模版的语法,类要这么写:

<#@ assembly name="System.Data" #>
<#@ import namespace="System.Data"#>
<#@ assembly name="MySql.Data"#>
<#@ import namespace="MySql.Data.MySqlClient"#>


<#+
	public class MySqlSummaryHelper
	{
		public readonly string ConnectionString = "server={0};user id={1};password={2};database=information_schema;";
        public DataTable dbSummary = new DataTable();
		public MySqlSummaryHelper(string server,string account,string password)
        {
			string commStr = string.Format(ConnectionString,server,account,password);
            using (MySqlConnection connection = new MySqlConnection(commStr))
            {
                string sql = "SELECT t.TABLE_NAME,t.TABLE_COMMENT,c.COLUMN_NAME,c.COLUMN_TYPE,c.COLUMN_COMMENT FROM information_schema.TABLES t,INFORMATION_SCHEMA.Columns c WHERE c.TABLE_NAME=t.TABLE_NAME AND t.`TABLE_SCHEMA`='zzw_power'";
                MySqlCommand command = new MySqlCommand(sql, connection);
                MySqlDataAdapter adapter = new MySqlDataAdapter(command);
                adapter.Fill(dbSummary);
            }
        }
		public string GetTableComment(string tableName)
		{
			string selectSql = string.Format("TABLE_NAME='{0}'",tableName);
			return this.dbSummary.Select(selectSql).First()["TABLE_COMMENT"].ToString();
        }
		
		public string GetColumnComment(string tableName,string columnName)
		{
			string selectSql = string.Format("TABLE_NAME='{0}' AND COLUMN_NAME='{1}'",tableName,columnName);
			return this.dbSummary.Select(selectSql).First()["COLUMN_COMMENT"].ToString();
        }
	}
#>

应该是比较好理解的,
<#@ assembly name="System.Data" #> 项目中的引用dll
<#@ import namespace="MySql.Data.MySqlClient"#> 类似using语法,就是打开命名空间
然后在<#+ public class xx{} #> 里面,写一个辅助类
实例化这个类,在构造参数中传入server、account、password,就可以通过GetTableComment和GetColumnComment两个方法去获取字段名了。
具体代码如下:
1、实例化一个对象,可以写在summary附近

MySqlSummaryHelper summaryDb = new MySqlSummaryHelper("127.0.0.1","root","123456");

2、还记得前面获取类注释和属性注释的时候,获取不到注释的处理么,我自己写了个字符串进去。
现在可以将那个字符串,换成方法的调用了,分别如下:

if(entity.Documentation !=null && entity.Documentation.Summary!=null)
	summary=entity.Documentation.Summary;
else
	summary=summaryDb.GetTableComment(entity.Name);
if (edmProperty.Documentation != null && edmProperty.Documentation.Summary != null)
{
	summary=edmProperty.Documentation.Summary;
}
else
{
	summary=summaryDb.GetColumnComment(edmProperty.DeclaringType.Name,edmProperty.Name);
}

这里讲解了大概的tt修改过程,以及修改的原因。
如果还有不理解的,建议搜索t4语法与调试技巧,花几分钟初步了解一下t4模版,想来会更好理解。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
EF Core框架中,数据库表的列名和实体类的属性名不一致是一个常见的情况。这种情况可能出现在数据库设计时,为了符合统一的命名规范,数据库表的列名可能使用下划线分隔,而实体类的属性名可能使用驼峰命名法。 为了解决这个问题EF Core提供了一些特性和约定,可以映射数据库列名和实体类属性名之间的关系。其中最常用的特性是`Column`和`Table`特性。 `Column`特性用于将实体类的属性映射到数据库表的列名。例如,如果数据库表中的列名是`first_name`,而实体类中的属性名是`FirstName`,可以在实体类的属性上使用`[Column("first_name")]`特性来进行映射。 `Table`特性用于将实体类映射到数据库表的名称。如果数据库表的名称与实体类的名称不一致,可以在实体类上使用`[Table("table_name")]`特性来指定对应的表名。 除了特性,EF Core还支持一些约定,根据命名规则自动进行映射。例如,默认情况下,EF Core会将实体类的属性名映射到数据库表的列名,只需保证它们的名称一致即可。如果数据库列名是多个单词的组合,使用下划线分隔,EF Core会将其转换为驼峰命名法。 总结来说,EF Core提供了特性和约定来处理数据库列名和实体类列名不一致的情况。通过使用`Column`和`Table`特性、遵循命名约定,可以实现灵活的映射,确保数据在实体类和数据库表之间的正确转换。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值