-
Notifications
You must be signed in to change notification settings - Fork 2
/
OleDbOracleDaLayer.cs
executable file
·130 lines (117 loc) · 5.2 KB
/
OleDbOracleDaLayer.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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
// Copyright (c) 2004-2010 Azavea, Inc.
//
// Permission is hereby granted, free of charge, to any person
// obtaining a copy of this software and associated documentation
// files (the "Software"), to deal in the Software without
// restriction, including without limitation the rights to use,
// copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following
// conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
// OTHER DEALINGS IN THE SOFTWARE.
using System;
using Azavea.Open.DAO.SQL;
namespace Azavea.Open.DAO.OleDb
{
/// <summary>
/// Implements a FastDao layer customized for PostGreSQL (optionally with PostGIS installed).
/// </summary>
public class OleDbOracleDaLayer : SqlDaDdlLayer
{
/// <summary>
/// Construct the layer. Should typically be called only by the appropriate
/// ConnectionDescriptor.
/// </summary>
/// <param name="connDesc">Connection to the Firebird DB we'll be using.</param>
public OleDbOracleDaLayer(OleDbDescriptor connDesc)
: base(connDesc, true) { }
#region Implementation of IDaDdlLayer
/// <summary>
/// Returns the DDL for the type of an automatically incrementing column.
/// Some databases only store autonums in one col type so baseType may be
/// ignored.
/// </summary>
/// <param name="baseType">The data type of the column (nominally).</param>
/// <returns>The autonumber definition string.</returns>
protected override string GetAutoType(Type baseType)
{
throw new NotSupportedException("Oracle does not have autonumbers, use a sequence.");
}
/// <summary>
/// Returns the SQL type used to store a byte array in the DB.
/// </summary>
protected override string GetByteArrayType()
{
return "BLOB";
}
/// <summary>
/// Returns the SQL type used to store a long in the DB.
/// </summary>
protected override string GetLongType()
{
return "BIGINT";
}
/// <summary>
/// Returns the SQL type used to store a "normal" (unicode) string in the DB.
/// </summary>
protected override string GetStringType()
{
return "VARCHAR2(2000)";
}
/// <summary>
/// Oracle doesn't seem to have a varchar type that is limited to ASCII characters.
/// </summary>
/// <returns></returns>
protected override string GetAsciiStringType()
{
return "VARCHAR2(2000)";
}
/// <summary>
/// Returns whether a sequence with this name exists or not.
/// Firebird doesn't appear to support the SQL standard information_schema.
/// </summary>
/// <param name="name">Name of the sequence to check for.</param>
/// <returns>Whether a sequence with this name exists in the data source.</returns>
public override bool SequenceExists(string name)
{
int count = SqlConnectionUtilities.XSafeIntQuery(_connDesc,
"SELECT count(*) FROM user_sequences WHERE sequence_name = '" +
name.ToUpper() + "'", null);
return count > 0;
}
/// <summary>
/// Returns true if you need to call "CreateStoreRoom" before storing any
/// data. This method is "Missing" not "Exists" because implementations that
/// do not use a store room can return "false" from this method without
/// breaking either a user's app or the spirit of the method.
///
/// Store room typically corresponds to "table".
/// </summary>
/// <returns>Returns true if you need to call "CreateStoreRoom"
/// before storing any data.</returns>
public override bool StoreRoomMissing(ClassMapping mapping)
{
// The user_tables doesn't store names with the owner prefix, remove it
// for the query
var start = mapping.Table.LastIndexOf('.');
// -1 is not found, but is not a good index, use 0
start = start != -1 ? (start + 1) : 0;
int count = SqlConnectionUtilities.XSafeIntQuery(_connDesc,
"SELECT COUNT(*) FROM user_tables where table_name = '" +
mapping.Table.Substring(start).ToUpper() + "'", null);
return count == 0;
}
#endregion
}
}