0
|
1 using System;
|
|
2 using System.Linq;
|
|
3
|
|
4 using BLToolkit.Data;
|
|
5 using BLToolkit.Data.Linq;
|
|
6
|
|
7 using NUnit.Framework;
|
|
8
|
|
9 namespace Data.Linq
|
|
10 {
|
|
11 using Model;
|
|
12
|
|
13 [TestFixture]
|
|
14 public class TableFunctionTest : TestBase
|
|
15 {
|
|
16 [Test]
|
|
17 public void Func1([IncludeDataContexts("Sql2008", "Sql2012")] string context)
|
|
18 {
|
|
19 using (var db = new TestDbManager(context))
|
|
20 {
|
|
21 var q =
|
|
22 from p in new Model.Functions(db).GetParentByID(1)
|
|
23 select p;
|
|
24
|
|
25 q.ToList();
|
|
26 }
|
|
27 }
|
|
28
|
|
29 [Test]
|
|
30 public void Func2([IncludeDataContexts("Sql2008", "Sql2012")] string context)
|
|
31 {
|
|
32 using (var db = new TestDbManager(context))
|
|
33 {
|
|
34 var q =
|
|
35 from c in db.Child
|
|
36 from p in db.GetParentByID(2)
|
|
37 select p;
|
|
38
|
|
39 q.ToList();
|
|
40 }
|
|
41 }
|
|
42
|
|
43 [Test]
|
|
44 public void Func3([IncludeDataContexts("Sql2008", "Sql2012")] string context)
|
|
45 {
|
|
46 using (var db = new TestDbManager(context))
|
|
47 {
|
|
48 var q =
|
|
49 from c in db.Child
|
|
50 from p in db.GetParentByID(c.ParentID)
|
|
51 select p;
|
|
52
|
|
53 q.ToList();
|
|
54 }
|
|
55 }
|
|
56
|
|
57 readonly Func<DbManager,int,IQueryable<Parent>> _f1 = CompiledQuery.Compile(
|
|
58 (DbManager db, int id) => from p in new Model.Functions(db).GetParentByID(id) select p);
|
|
59
|
|
60 [Test]
|
|
61 public void CompiledFunc1([IncludeDataContexts("Sql2008", "Sql2012")] string context)
|
|
62 {
|
|
63 using (var db = new TestDbManager(context))
|
|
64 {
|
|
65 var q = _f1(db, 1);
|
|
66 q.ToList();
|
|
67 }
|
|
68 }
|
|
69
|
|
70 readonly Func<TestDbManager,int,IQueryable<Parent>> _f2 = CompiledQuery.Compile(
|
|
71 (TestDbManager db, int id) => from c in db.Child from p in db.GetParentByID(id) select p);
|
|
72
|
|
73 [Test]
|
|
74 public void CompiledFunc2([IncludeDataContexts("Sql2008", "Sql2012")] string context)
|
|
75 {
|
|
76 using (var db = new TestDbManager(context))
|
|
77 {
|
|
78 var q = _f2(db, 1);
|
|
79 q.ToList();
|
|
80 }
|
|
81 }
|
|
82
|
|
83 [Test]
|
|
84 public void WithTabLock([IncludeDataContexts("Sql2008", "Sql2012")] string context)
|
|
85 {
|
|
86 using (var db = new TestDbManager(context))
|
|
87 {
|
|
88 var q =
|
|
89 from p in new Model.Functions(db).WithTabLock<Parent>()
|
|
90 select p;
|
|
91
|
|
92 q.ToList();
|
|
93 }
|
|
94 }
|
|
95
|
|
96 [Test, Category("FULLTEXT")]
|
|
97 public void FreeText1([IncludeDataContexts("Northwind")] string context)
|
|
98 {
|
|
99 using (var db = new NorthwindDB())
|
|
100 {
|
|
101 var q =
|
|
102 from c in db.Category
|
|
103 join t in db.FreeTextTable<Northwind.Category,int>("[Description]", "sweetest candy bread and dry meat")
|
|
104 on c.CategoryID equals t.Key
|
|
105 select c;
|
|
106
|
|
107 q.ToList();
|
|
108 }
|
|
109 }
|
|
110
|
|
111 [Test, Category("FULLTEXT")]
|
|
112 public void FreeText2([IncludeDataContexts("Northwind")] string context)
|
|
113 {
|
|
114 using (var db = new NorthwindDB())
|
|
115 {
|
|
116 var q =
|
|
117 from c in db.Category
|
|
118 join t in db.FreeTextTable<Northwind.Category,int>(c => c.Description, "sweetest candy bread and dry meat")
|
|
119 on c.CategoryID equals t.Key
|
|
120 select c;
|
|
121
|
|
122 q.ToList();
|
|
123 }
|
|
124 }
|
|
125
|
|
126 [Test, Category("FULLTEXT")]
|
|
127 public void FreeText3([IncludeDataContexts("Northwind")] string context)
|
|
128 {
|
|
129 using (var db = new NorthwindDB())
|
|
130 {
|
|
131 var q =
|
|
132 from t in db.FreeTextTable<Northwind.Category,int>(c => c.Description, "sweetest candy bread and dry meat")
|
|
133 join c in db.Category
|
|
134 on t.Key equals c.CategoryID
|
|
135 select c;
|
|
136
|
|
137 q.ToList();
|
|
138 }
|
|
139 }
|
|
140 }
|
|
141 }
|