-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathMySQL57SpatialQueriesFixture.cs
111 lines (98 loc) · 2.93 KB
/
MySQL57SpatialQueriesFixture.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
using NHibernate;
using NHibernate.Cfg;
using NHibernate.Spatial.Dialect;
using NUnit.Framework;
using Tests.NHibernate.Spatial.RandomGeometries;
namespace Tests.NHibernate.Spatial
{
[TestFixture]
public class MySQL57SpatialQueriesFixture : SpatialQueriesFixture
{
protected override void Configure(Configuration configuration)
{
TestConfiguration.Configure(configuration);
}
protected override string SqlLineStringFilter(string filterString)
{
return $@"
SELECT count(*)
FROM linestringtest
WHERE MBRIntersects(the_geom, GeomFromText('{filterString}', 4326))
";
}
protected override string SqlPolygonFilter(string filterString)
{
return $@"
SELECT count(*)
FROM polygontest
WHERE MBRIntersects(the_geom, GeomFromText('{filterString}', 4326))
";
}
protected override string SqlMultiLineStringFilter(string filterString)
{
return $@"
SELECT count(*)
FROM multilinestringtest
WHERE MBRIntersects(the_geom, GeomFromText('{filterString}', 4326))
";
}
protected override string SqlOvelapsLineString(string filterString)
{
return $@"
SELECT count(*)
FROM linestringtest
WHERE the_geom IS NOT NULL
AND {SpatialDialect.IsoPrefix}Overlaps(PolygonFromText('{filterString}', 4326), the_geom)
";
}
protected override string SqlIntersectsLineString(string filterString)
{
return $@"
SELECT count(*)
FROM linestringtest
WHERE the_geom IS NOT NULL
AND {SpatialDialect.IsoPrefix}Intersects(PolygonFromText('{filterString}', 4326), the_geom)
";
}
protected override ISQLQuery SqlIsEmptyLineString(ISession session)
{
return session.CreateSQLQuery($@"
SELECT {SpatialDialect.IsoPrefix}IsEmpty(the_geom) as result
FROM linestringtest
WHERE oid = ?
AND the_geom IS NOT NULL
")
.AddScalar("result", NHibernateUtil.Boolean);
}
protected override ISQLQuery SqlIsSimpleLineString(ISession session)
{
return session.CreateSQLQuery($@"
SELECT {SpatialDialect.IsoPrefix}IsSimple(the_geom) as result
FROM linestringtest
WHERE oid = ?
AND the_geom IS NOT NULL
")
.AddScalar("result", NHibernateUtil.Boolean);
}
protected override ISQLQuery SqlAsBinaryLineString(ISession session)
{
return session.CreateSQLQuery($@"
SELECT {SpatialDialect.IsoPrefix}AsBinary(the_geom) as result
FROM linestringtest
WHERE oid = ?
AND the_geom IS NOT NULL
")
.AddScalar("result", NHibernateUtil.BinaryBlob);
}
#region Unsupported features
[Test]
[Ignore("Provider does not support the Boundary function")]
public override void HqlBoundary()
{ }
[Test]
[Ignore("Provider does not support the Relate function")]
public override void HqlRelateLineString()
{ }
#endregion
}
}