Skip to content

Commit 7e61d73

Browse files
authored
Merge pull request #1483 from BobLi-Net/master
增加dbfirst
2 parents 181fb90 + a264578 commit 7e61d73

File tree

4 files changed

+69
-16
lines changed

4 files changed

+69
-16
lines changed

FreeSql.DbContext/FreeSql.DbContext.xml

Lines changed: 18 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

FreeSql.Tests/FreeSql.Tests.Provider.Xugu/UnitDbFirst.cs

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -22,16 +22,20 @@ public void GetTablesByDatabase()
2222
public void GetTableByName()
2323
{
2424
var fsql = g.xugu;
25-
var t1 = fsql.DbFirst.GetTableByName("GENERAL.system_log");
26-
Assert.NotNull(t1);
27-
Assert.True(t1.Columns.Count > 0);
25+
fsql.CodeFirst.SyncStructure(typeof(test_existstb01));
26+
var t1 = fsql.DbFirst.GetTableByName("test_existstb01");
27+
Assert.NotNull(t1);
28+
Assert.True(t1.Columns.Count > 0);
29+
var t3 = fsql.DbFirst.GetTableByName("notexists_tb");
30+
Assert.Null(t3);
31+
fsql.Ado.ExecuteNonQuery("drop table test_existstb01");
2832
}
2933

3034
[Fact]
3135
public void ExistsTable()
3236
{
3337
var fsql = g.xugu;
34-
Assert.False(fsql.DbFirst.ExistsTable("GENERAL.system_log"));
38+
Assert.False(fsql.DbFirst.ExistsTable("test_existstb01"));
3539
fsql.CodeFirst.SyncStructure(typeof(test_existstb01));
3640
Assert.True(fsql.DbFirst.ExistsTable("test_existstb01"));
3741
fsql.Ado.ExecuteNonQuery("drop table test_existstb01");

FreeSql.sln

Lines changed: 16 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -123,6 +123,8 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "FreeSql.Extensions.Aggregat
123123
EndProject
124124
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "FreeSql.Provider.Xugu", "Providers\FreeSql.Provider.Xugu\FreeSql.Provider.Xugu.csproj", "{8064870C-22EA-4A58-972D-DBD57D096D91}"
125125
EndProject
126+
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "FreeSql.Tests.Provider.Xugu", "FreeSql.Tests\FreeSql.Tests.Provider.Xugu\FreeSql.Tests.Provider.Xugu.csproj", "{16C21D77-20AC-4722-AD97-F53BDDE8210C}"
127+
EndProject
126128
Global
127129
GlobalSection(SolutionConfigurationPlatforms) = preSolution
128130
Debug|Any CPU = Debug|Any CPU
@@ -733,6 +735,18 @@ Global
733735
{8064870C-22EA-4A58-972D-DBD57D096D91}.Release|x64.Build.0 = Release|Any CPU
734736
{8064870C-22EA-4A58-972D-DBD57D096D91}.Release|x86.ActiveCfg = Release|Any CPU
735737
{8064870C-22EA-4A58-972D-DBD57D096D91}.Release|x86.Build.0 = Release|Any CPU
738+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
739+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Debug|Any CPU.Build.0 = Debug|Any CPU
740+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Debug|x64.ActiveCfg = Debug|Any CPU
741+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Debug|x64.Build.0 = Debug|Any CPU
742+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Debug|x86.ActiveCfg = Debug|Any CPU
743+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Debug|x86.Build.0 = Debug|Any CPU
744+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Release|Any CPU.ActiveCfg = Release|Any CPU
745+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Release|Any CPU.Build.0 = Release|Any CPU
746+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Release|x64.ActiveCfg = Release|Any CPU
747+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Release|x64.Build.0 = Release|Any CPU
748+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Release|x86.ActiveCfg = Release|Any CPU
749+
{16C21D77-20AC-4722-AD97-F53BDDE8210C}.Release|x86.Build.0 = Release|Any CPU
736750
EndGlobalSection
737751
GlobalSection(SolutionProperties) = preSolution
738752
HideSolutionNode = FALSE
@@ -775,8 +789,8 @@ Global
775789
{8064870C-22EA-4A58-972D-DBD57D096D91} = {2A381C57-2697-427B-9F10-55DA11FD02E4}
776790
EndGlobalSection
777791
GlobalSection(ExtensibilityGlobals) = postSolution
778-
SolutionGuid = {089687FD-5D25-40AB-BA8A-A10D1E137F98}
779-
RESX_PrefixTranslations = True
780792
RESX_NeutralResourcesLanguage = en-US
793+
RESX_PrefixTranslations = True
794+
SolutionGuid = {089687FD-5D25-40AB-BA8A-A10D1E137F98}
781795
EndGlobalSection
782796
EndGlobal

Providers/FreeSql.Provider.Xugu/XuguDbFirst.cs

Lines changed: 27 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -442,14 +442,15 @@ from all_INDEXES a
442442
{
443443
sql = $@"
444444
select
445-
schema_name || '.' || b.table_name as table_id,
446-
cons_name as FKId,
447-
cons_type,
448-
define
445+
c.schema_name || '.' || b.table_name as table_id,
446+
a.cons_name as FKId,
447+
a.cons_type,
448+
a.define,
449+
(select c2.schema_name || '.' || b2.table_name from all_tables as b2 left join all_SCHEMAS as c2 on b2.SCHEMA_ID=c2.SCHEMA_ID where b2.TABLE_id=b.table_id) as ref_table_id
449450
from all_constraints as a
450451
left join all_tables as b on a.Table_ID=b.Table_ID
451452
left Join all_SCHEMAS AS c on b.SCHEMA_ID=c.SCHEMA_ID
452-
where IS_SYS=false AND {loc8.ToString().Replace("a.table_name", "schema_name || '.' || b.table_name")}
453+
where IS_SYS=false AND a.cons_type='F' AND {loc8.ToString().Replace("a.table_name", "schema_name || '.' || b.table_name")}
453454
";
454455
ds = _orm.Ado.ExecuteArray(CommandType.Text, sql);
455456
if (ds == null) return loc1;
@@ -458,15 +459,31 @@ from all_constraints as a
458459
foreach (object[] row in ds)
459460
{
460461
var table_id = string.Concat(row[0]);
461-
var column = row[3] as string[];
462+
var ref_table_id = string.Concat(row[4]);
463+
//var ref_table_id = row[4] as long?;
464+
//if (!ref_table_id.HasValue || ref_table_id < 1)
465+
// continue;
466+
467+
//loc2 是所有表信息
468+
469+
if (!string.IsNullOrWhiteSpace(ref_table_id) || loc2.ContainsKey(ref_table_id?.ToString()) == false) continue;
470+
471+
472+
var column_temps = (row[3] as string)
473+
.Replace(")(", "|")
474+
.Replace("\"","")
475+
.Replace("(", "")
476+
.Replace(")", "")
477+
.Split('|');
478+
var column = column_temps[0].Split(',');
462479
var fk_id = string.Concat(row[1]);
463-
var ref_table_id = string.Concat(row[0]);
464-
var is_foreign_key = string.Concat(row[2]) == "F";
465-
var referenced_column = row[5] as string[];
480+
481+
//var is_foreign_key = string.Concat(row[2]) == "F";
482+
var referenced_column = column_temps[1].Split(',');
466483
//var referenced_db = string.Concat(row[6]);
467484
//var referenced_table = string.Concat(row[7]);
468485

469-
if (loc2.ContainsKey(ref_table_id) == false) continue;
486+
470487

471488
Dictionary<string, DbForeignInfo> loc12 = null;
472489
DbForeignInfo loc13 = null;

0 commit comments

Comments
 (0)