Skip to content

Commit 1fc4c9c

Browse files
committed
- 优化 MySql CodeFirst 索引的建立 ;#498
1 parent 698ace9 commit 1fc4c9c

File tree

4 files changed

+21
-20
lines changed

4 files changed

+21
-20
lines changed

Providers/FreeSql.Provider.MySql/FreeSql.Provider.MySql.csproj

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -26,7 +26,7 @@
2626
</ItemGroup>
2727

2828
<ItemGroup Condition="'$(TargetFramework)' == 'netstandard2.0' or '$(TargetFramework)' == 'net452'">
29-
<PackageReference Include="MySql.Data" Version="8.0.22" />
29+
<PackageReference Include="MySql.Data" Version="8.0.21" />
3030
</ItemGroup>
3131

3232
<ItemGroup Condition="'$(TargetFramework)' == 'net451' or '$(TargetFramework)' == 'net45' or '$(TargetFramework)' == 'net40'">

Providers/FreeSql.Provider.MySql/MySqlCodeFirst.cs

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -151,25 +151,25 @@ protected override string GetComparisonDDLStatements(params TypeAndName[] object
151151
foreach (var tbcol in tb.Primarys) sb.Append(_commonUtils.QuoteSqlName(tbcol.Attribute.Name)).Append(", ");
152152
sb.Remove(sb.Length - 2, 2).Append("),");
153153
}
154-
sb.Remove(sb.Length - 1, 1);
155-
sb.Append("\r\n) Engine=InnoDB");
156-
if (string.IsNullOrEmpty(tb.Comment) == false)
157-
sb.Append(" Comment=").Append(_commonUtils.FormatSql("{0}", tb.Comment));
158-
sb.Append(";\r\n");
159-
//创建表的索引
154+
//创建表的索引,感谢 @mafeng8,这样写可以支持自增不是主键的情况
160155
foreach (var uk in tb.Indexes)
161156
{
162-
sb.Append("CREATE ");
157+
sb.Append(" \r\n ");
163158
if (uk.IsUnique) sb.Append("UNIQUE ");
164-
sb.Append("INDEX ").Append(_commonUtils.QuoteSqlName(ReplaceIndexName(uk.Name, tbname[1]))).Append(" ON ").Append(createTableName).Append("(");
159+
sb.Append("INDEX ").Append(_commonUtils.QuoteSqlName(ReplaceIndexName(uk.Name, tbname[1]))).Append("(");
165160
foreach (var tbcol in uk.Columns)
166161
{
167162
sb.Append(_commonUtils.QuoteSqlName(tbcol.Column.Attribute.Name));
168163
if (tbcol.IsDesc) sb.Append(" DESC");
169164
sb.Append(", ");
170165
}
171-
sb.Remove(sb.Length - 2, 2).Append(");\r\n");
166+
sb.Remove(sb.Length - 2, 2).Append("),");
172167
}
168+
sb.Remove(sb.Length - 1, 1);
169+
sb.Append("\r\n) Engine=InnoDB");
170+
if (string.IsNullOrEmpty(tb.Comment) == false)
171+
sb.Append(" Comment=").Append(_commonUtils.FormatSql("{0}", tb.Comment));
172+
sb.Append(";\r\n");
173173
continue;
174174
}
175175
//如果新表,旧表在一个数据库下,直接修改表名

Providers/FreeSql.Provider.Odbc/MySql/OdbcMySqlCodeFirst.cs

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -140,25 +140,25 @@ protected override string GetComparisonDDLStatements(params TypeAndName[] object
140140
foreach (var tbcol in tb.Primarys) sb.Append(_commonUtils.QuoteSqlName(tbcol.Attribute.Name)).Append(", ");
141141
sb.Remove(sb.Length - 2, 2).Append("),");
142142
}
143-
sb.Remove(sb.Length - 1, 1);
144-
sb.Append("\r\n) Engine=InnoDB");
145-
if (string.IsNullOrEmpty(tb.Comment) == false)
146-
sb.Append(" Comment=").Append(_commonUtils.FormatSql("{0}", tb.Comment));
147-
sb.Append(";\r\n");
148-
//创建表的索引
143+
//创建表的索引,感谢 @mafeng8,这样写可以支持自增不是主键的情况
149144
foreach (var uk in tb.Indexes)
150145
{
151-
sb.Append("CREATE ");
146+
sb.Append(" \r\n ");
152147
if (uk.IsUnique) sb.Append("UNIQUE ");
153-
sb.Append("INDEX ").Append(_commonUtils.QuoteSqlName(ReplaceIndexName(uk.Name, tbname[1]))).Append(" ON ").Append(createTableName).Append("(");
148+
sb.Append("INDEX ").Append(_commonUtils.QuoteSqlName(ReplaceIndexName(uk.Name, tbname[1]))).Append("(");
154149
foreach (var tbcol in uk.Columns)
155150
{
156151
sb.Append(_commonUtils.QuoteSqlName(tbcol.Column.Attribute.Name));
157152
if (tbcol.IsDesc) sb.Append(" DESC");
158153
sb.Append(", ");
159154
}
160-
sb.Remove(sb.Length - 2, 2).Append(");\r\n");
155+
sb.Remove(sb.Length - 2, 2).Append("),");
161156
}
157+
sb.Remove(sb.Length - 1, 1);
158+
sb.Append("\r\n) Engine=InnoDB");
159+
if (string.IsNullOrEmpty(tb.Comment) == false)
160+
sb.Append(" Comment=").Append(_commonUtils.FormatSql("{0}", tb.Comment));
161+
sb.Append(";\r\n");
162162
continue;
163163
}
164164
//如果新表,旧表在一个数据库下,直接修改表名

readme.md

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -182,7 +182,8 @@ Elapsed: 00:00:00.6495301; Query Entity Counts: 131072; ORM: Dapper
182182
[tky753](https://github.com/tky753)
183183
[feijie999](https://github.com/feijie999)
184184
constantine、
185-
[JohnZhou2020](https://github.com/JohnZhou2020)
185+
[JohnZhou2020](https://github.com/JohnZhou2020)
186+
[mafeng8](https://github.com/mafeng8)
186187

187188
QQ群:4336577(已满)、8578575(在线)、52508226(在线)
188189

0 commit comments

Comments
 (0)