mirror of
				https://github.com/nsnail/FreeSql.git
				synced 2025-11-04 01:05:27 +08:00 
			
		
		
		
	- 优化 MySql CodeFirst 索引的建立 ;#498
This commit is contained in:
		@@ -26,7 +26,7 @@
 | 
			
		||||
  </ItemGroup>
 | 
			
		||||
 | 
			
		||||
  <ItemGroup Condition="'$(TargetFramework)' == 'netstandard2.0' or '$(TargetFramework)' == 'net452'">
 | 
			
		||||
    <PackageReference Include="MySql.Data" Version="8.0.22" />
 | 
			
		||||
    <PackageReference Include="MySql.Data" Version="8.0.21" />
 | 
			
		||||
  </ItemGroup>
 | 
			
		||||
 | 
			
		||||
  <ItemGroup Condition="'$(TargetFramework)' == 'net451' or '$(TargetFramework)' == 'net45' or '$(TargetFramework)' == 'net40'">
 | 
			
		||||
 
 | 
			
		||||
@@ -151,25 +151,25 @@ namespace FreeSql.MySql
 | 
			
		||||
                                foreach (var tbcol in tb.Primarys) sb.Append(_commonUtils.QuoteSqlName(tbcol.Attribute.Name)).Append(", ");
 | 
			
		||||
                                sb.Remove(sb.Length - 2, 2).Append("),");
 | 
			
		||||
                            }
 | 
			
		||||
                            sb.Remove(sb.Length - 1, 1);
 | 
			
		||||
                            sb.Append("\r\n) Engine=InnoDB");
 | 
			
		||||
                            if (string.IsNullOrEmpty(tb.Comment) == false)
 | 
			
		||||
                                sb.Append(" Comment=").Append(_commonUtils.FormatSql("{0}", tb.Comment));
 | 
			
		||||
                            sb.Append(";\r\n");
 | 
			
		||||
                            //创建表的索引
 | 
			
		||||
                            //创建表的索引,感谢 @mafeng8,这样写可以支持自增不是主键的情况
 | 
			
		||||
                            foreach (var uk in tb.Indexes)
 | 
			
		||||
                            {
 | 
			
		||||
                                sb.Append("CREATE ");
 | 
			
		||||
                                sb.Append(" \r\n  ");
 | 
			
		||||
                                if (uk.IsUnique) sb.Append("UNIQUE ");
 | 
			
		||||
                                sb.Append("INDEX ").Append(_commonUtils.QuoteSqlName(ReplaceIndexName(uk.Name, tbname[1]))).Append(" ON ").Append(createTableName).Append("(");
 | 
			
		||||
                                sb.Append("INDEX ").Append(_commonUtils.QuoteSqlName(ReplaceIndexName(uk.Name, tbname[1]))).Append("(");
 | 
			
		||||
                                foreach (var tbcol in uk.Columns)
 | 
			
		||||
                                {
 | 
			
		||||
                                    sb.Append(_commonUtils.QuoteSqlName(tbcol.Column.Attribute.Name));
 | 
			
		||||
                                    if (tbcol.IsDesc) sb.Append(" DESC");
 | 
			
		||||
                                    sb.Append(", ");
 | 
			
		||||
                                }
 | 
			
		||||
                                sb.Remove(sb.Length - 2, 2).Append(");\r\n");
 | 
			
		||||
                                sb.Remove(sb.Length - 2, 2).Append("),");
 | 
			
		||||
                            }
 | 
			
		||||
                            sb.Remove(sb.Length - 1, 1);
 | 
			
		||||
                            sb.Append("\r\n) Engine=InnoDB");
 | 
			
		||||
                            if (string.IsNullOrEmpty(tb.Comment) == false)
 | 
			
		||||
                                sb.Append(" Comment=").Append(_commonUtils.FormatSql("{0}", tb.Comment));
 | 
			
		||||
                            sb.Append(";\r\n");
 | 
			
		||||
                            continue;
 | 
			
		||||
                        }
 | 
			
		||||
                        //如果新表,旧表在一个数据库下,直接修改表名
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user