mirror of
https://github.com/nsnail/FreeSql.git
synced 2025-04-22 10:42:52 +08:00
- 优化 MySql CodeFirst 索引的建立 ;#498
This commit is contained in:
parent
698ace9674
commit
1fc4c9c46e
@ -26,7 +26,7 @@
|
|||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup Condition="'$(TargetFramework)' == 'netstandard2.0' or '$(TargetFramework)' == 'net452'">
|
<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>
|
||||||
|
|
||||||
<ItemGroup Condition="'$(TargetFramework)' == 'net451' or '$(TargetFramework)' == 'net45' or '$(TargetFramework)' == 'net40'">
|
<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(", ");
|
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 - 2, 2).Append("),");
|
||||||
}
|
}
|
||||||
sb.Remove(sb.Length - 1, 1);
|
//创建表的索引,感谢 @mafeng8,这样写可以支持自增不是主键的情况
|
||||||
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");
|
|
||||||
//创建表的索引
|
|
||||||
foreach (var uk in tb.Indexes)
|
foreach (var uk in tb.Indexes)
|
||||||
{
|
{
|
||||||
sb.Append("CREATE ");
|
sb.Append(" \r\n ");
|
||||||
if (uk.IsUnique) sb.Append("UNIQUE ");
|
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)
|
foreach (var tbcol in uk.Columns)
|
||||||
{
|
{
|
||||||
sb.Append(_commonUtils.QuoteSqlName(tbcol.Column.Attribute.Name));
|
sb.Append(_commonUtils.QuoteSqlName(tbcol.Column.Attribute.Name));
|
||||||
if (tbcol.IsDesc) sb.Append(" DESC");
|
if (tbcol.IsDesc) sb.Append(" DESC");
|
||||||
sb.Append(", ");
|
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;
|
continue;
|
||||||
}
|
}
|
||||||
//如果新表,旧表在一个数据库下,直接修改表名
|
//如果新表,旧表在一个数据库下,直接修改表名
|
||||||
|
@ -140,25 +140,25 @@ namespace FreeSql.Odbc.MySql
|
|||||||
foreach (var tbcol in tb.Primarys) sb.Append(_commonUtils.QuoteSqlName(tbcol.Attribute.Name)).Append(", ");
|
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 - 2, 2).Append("),");
|
||||||
}
|
}
|
||||||
sb.Remove(sb.Length - 1, 1);
|
//创建表的索引,感谢 @mafeng8,这样写可以支持自增不是主键的情况
|
||||||
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");
|
|
||||||
//创建表的索引
|
|
||||||
foreach (var uk in tb.Indexes)
|
foreach (var uk in tb.Indexes)
|
||||||
{
|
{
|
||||||
sb.Append("CREATE ");
|
sb.Append(" \r\n ");
|
||||||
if (uk.IsUnique) sb.Append("UNIQUE ");
|
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)
|
foreach (var tbcol in uk.Columns)
|
||||||
{
|
{
|
||||||
sb.Append(_commonUtils.QuoteSqlName(tbcol.Column.Attribute.Name));
|
sb.Append(_commonUtils.QuoteSqlName(tbcol.Column.Attribute.Name));
|
||||||
if (tbcol.IsDesc) sb.Append(" DESC");
|
if (tbcol.IsDesc) sb.Append(" DESC");
|
||||||
sb.Append(", ");
|
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;
|
continue;
|
||||||
}
|
}
|
||||||
//如果新表,旧表在一个数据库下,直接修改表名
|
//如果新表,旧表在一个数据库下,直接修改表名
|
||||||
|
@ -182,7 +182,8 @@ Elapsed: 00:00:00.6495301; Query Entity Counts: 131072; ORM: Dapper
|
|||||||
[tky753](https://github.com/tky753)、
|
[tky753](https://github.com/tky753)、
|
||||||
[feijie999](https://github.com/feijie999)、
|
[feijie999](https://github.com/feijie999)、
|
||||||
constantine、
|
constantine、
|
||||||
[JohnZhou2020](https://github.com/JohnZhou2020)
|
[JohnZhou2020](https://github.com/JohnZhou2020)、
|
||||||
|
[mafeng8](https://github.com/mafeng8)
|
||||||
|
|
||||||
QQ群:4336577(已满)、8578575(在线)、52508226(在线)
|
QQ群:4336577(已满)、8578575(在线)、52508226(在线)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user