-
Notifications
You must be signed in to change notification settings - Fork 935
/
Copy pathANSIJoinFragment.cs
113 lines (97 loc) · 2.76 KB
/
ANSIJoinFragment.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
using NHibernate.Util;
namespace NHibernate.SqlCommand
{
/// <summary>
/// An ANSI-style Join.
/// </summary>
public class ANSIJoinFragment : JoinFragment
{
private SqlStringBuilder _fromFragment = new SqlStringBuilder();
private readonly SqlStringBuilder _whereFragment = new SqlStringBuilder();
public override void AddJoin(string tableName, string alias, string[] fkColumns, string[] pkColumns, JoinType joinType)
{
AddJoin(tableName, alias, fkColumns, pkColumns, joinType, null);
}
public override void AddJoin(string tableName, string alias, string[] fkColumns, string[] pkColumns, JoinType joinType,
SqlString on)
{
var joinString = GetJoinString(joinType);
_fromFragment.Add(joinString).Add(tableName).Add(" ").Add(alias).Add(" ");
if (joinType == JoinType.CrossJoin)
{
// Cross join does not have an 'on' statement
return;
}
_fromFragment.Add("on ");
if (fkColumns.Length == 0)
{
AddBareCondition(_fromFragment, on);
return;
}
for (int j = 0; j < fkColumns.Length; j++)
{
_fromFragment.Add(fkColumns[j] + "=" + alias + StringHelper.Dot + pkColumns[j]);
if (j < fkColumns.Length - 1)
{
_fromFragment.Add(" and ");
}
}
AddCondition(_fromFragment, on);
}
internal static string GetJoinString(JoinType joinType)
{
switch (joinType)
{
case JoinType.InnerJoin:
return " inner join ";
case JoinType.LeftOuterJoin:
return " left outer join ";
case JoinType.RightOuterJoin:
return " right outer join ";
case JoinType.FullJoin:
return " full outer join ";
case JoinType.CrossJoin:
return " cross join ";
default:
throw new AssertionFailure("undefined join type");
}
}
public override SqlString ToFromFragmentString
{
get { return _fromFragment.ToSqlString(); }
}
public override SqlString ToWhereFragmentString
{
get { return _whereFragment.ToSqlString(); }
}
public override void AddJoins(SqlString fromFragment, SqlString whereFragment)
{
_fromFragment.Add(fromFragment);
//where fragment must be empty!
}
public JoinFragment Copy()
{
var copy = new ANSIJoinFragment
{
_fromFragment = new SqlStringBuilder(_fromFragment.ToSqlString())
};
return copy;
}
public override void AddCrossJoin(string tableName, string alias)
{
_fromFragment.Add(StringHelper.CommaSpace + tableName + " " + alias);
}
public override bool AddCondition(string condition)
{
return AddCondition(_whereFragment, condition);
}
public override bool AddCondition(SqlString condition)
{
return AddCondition(_whereFragment, condition);
}
public override void AddFromFragmentString(SqlString fromFragmentString)
{
_fromFragment.Add(fromFragmentString);
}
}
}