annotate Source/Data/DataProvider/FdpDataProvider.cs @ 0:f990fcb411a9

Копия текущей версии из github
author cin
date Thu, 27 Mar 2014 21:46:09 +0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
1 /***
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
2
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
3 * FdpDataProvider
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
4 needed FirebirdClient http://sourceforge.net/project/showfiles.php?group_id=9028&package_id=62107
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
5 tested with FirebirdClient 2.1.0 Beta 3
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
6
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
7 Known troubles:
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
8 1) Some tests fails due to Fb SQL-syntax specific
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
9 2) ResultSet mapping doesn't work - not supported by client
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
10 3) UnitTests.CS.DataAccess.OutRefTest tests: Test2 && TestNullable2 doesnt work:
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
11 parameters directions should be provided correctly to functions run, that's why
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
12 output parameterd would be mapped to Entity e, so asserts should be same a in Test1.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
13
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
14 "Features"
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
15 1) Type conversation due to http://www.firebirdsql.org/manual/migration-mssql-data-types.html
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
16 BUT! for Binary types BLOB is used! not CHAR!
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
17 2) InOut parameters faking: InOut parameters are not suppotred by Fb, but they could be
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
18 emulated: each InOut parameter should be defined in RETURNS() section, and allso has a mirror
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
19 in parameter section with name [prefix][inOutParameterName], see OutRefTest SP. Faking settings:
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
20 FdpDataProvider.InOutInputParameterPrefix = "in_";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
21 FdpDataProvider.IsInOutParameterEmulation = true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
22 3) Returned values faking. Each parameter with "magic name" woul be treated as ReturnValue.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
23 see Scalar_ReturnParameter SP. Faking settings:
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
24 FdpDataProvider.ReturnParameterName = "RETURN_VALUE";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
25 FdpDataProvider.IsReturnValueEmulation = true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
26
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
27 */
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
28
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
29 using System;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
30 using System.Collections.Generic;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
31 using System.Collections.Specialized;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
32 using System.Data;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
33 using System.Data.Common;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
34 using System.Linq;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
35
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
36 using BLToolkit.Data.Sql.SqlProvider;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
37 using BLToolkit.Mapping;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
38 using BLToolkit.Reflection;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
39
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
40 using FirebirdSql.Data.FirebirdClient;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
41
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
42 namespace BLToolkit.Data.DataProvider
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
43 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
44 public class FdpDataProvider : DataProviderBase
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
45 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
46 public FdpDataProvider()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
47 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
48 MappingSchema = new FbMappingSchema();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
49 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
50
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
51 #region InOut & ReturnValue emulation
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
52 public static string InOutInputParameterPrefix = "in_";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
53 public static string ReturnParameterName = "RETURN_VALUE";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
54
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
55 public static bool IsReturnValueEmulation = true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
56 public static bool IsInOutParameterEmulation = true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
57
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
58 public static bool QuoteIdentifiers
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
59 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
60 get { return FirebirdSqlProvider.QuoteIdentifiers; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
61 set { FirebirdSqlProvider.QuoteIdentifiers = value; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
62 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
63 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
64
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
65 #region Overloads
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
66 public override Type ConnectionType
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
67 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
68 get { return typeof (FbConnection); }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
69 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
70
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
71 public override string Name
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
72 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
73 get { return DataProvider.ProviderName.Firebird; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
74 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
75
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
76 public override int MaxBatchSize
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
77 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
78 get { return 0; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
79 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
80
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
81 public override IDbConnection CreateConnectionObject()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
82 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
83 return new FbConnection();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
84 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
85
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
86 public override DbDataAdapter CreateDataAdapterObject()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
87 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
88 return new FbDataAdapter();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
89 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
90
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
91 public override bool DeriveParameters(IDbCommand command)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
92 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
93 if (command is FbCommand)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
94 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
95 FbCommandBuilder.DeriveParameters((FbCommand) command);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
96
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
97 if (IsReturnValueEmulation)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
98 foreach (IDbDataParameter par in command.Parameters)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
99 if (IsReturnValue(par))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
100 par.Direction = ParameterDirection.ReturnValue;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
101
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
102 return true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
103 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
104
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
105 return false;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
106 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
107
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
108 public override object Convert(object value, ConvertType convertType)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
109 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
110 switch (convertType)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
111 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
112 case ConvertType.ExceptionToErrorNumber:
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
113 if (value is FbException)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
114 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
115 var ex = (FbException) value;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
116 if (ex.Errors.Count > 0)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
117 foreach (FbError error in ex.Errors)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
118 return error.Number;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
119 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
120
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
121 break;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
122 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
123
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
124 return SqlProvider.Convert(value, convertType);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
125 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
126
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
127 public override ISqlProvider CreateSqlProvider()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
128 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
129 return new FirebirdSqlProvider();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
130 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
131
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
132 public override bool IsValueParameter(IDbDataParameter parameter)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
133 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
134 return parameter.Direction != ParameterDirection.ReturnValue
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
135 && parameter.Direction != ParameterDirection.Output;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
136 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
137
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
138 private string GetInputParameterName(string ioParameterName)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
139 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
140 return (string) Convert(
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
141 InOutInputParameterPrefix + (string) Convert(ioParameterName, ConvertType.SprocParameterToName),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
142 ConvertType.NameToSprocParameter);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
143 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
144
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
145 private static IDbDataParameter GetParameter(string parameterName, IEnumerable<IDbDataParameter> commandParameters)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
146 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
147 return commandParameters.FirstOrDefault(par => string.Compare(parameterName, par.ParameterName, true) == 0);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
148 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
149
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
150 private bool IsReturnValue(IDbDataParameter parameter)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
151 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
152 if (string.Compare(parameter.ParameterName,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
153 (string) Convert(ReturnParameterName, ConvertType.NameToSprocParameter), true) == 0
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
154 )
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
155 return true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
156
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
157 return false;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
158 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
159
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
160 public override void PrepareCommand(ref CommandType commandType, ref string commandText,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
161 ref IDbDataParameter[] commandParameters)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
162 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
163 if (commandParameters != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
164 foreach (var par in commandParameters)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
165 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
166 if (par.Value is bool)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
167 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
168 var value = (bool) par.Value ? "1" : "0";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
169
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
170 par.DbType = DbType.AnsiString;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
171 par.Value = value;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
172 par.Size = value.Length;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
173 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
174 else if (par.Value is Guid)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
175 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
176 var value = par.Value.ToString();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
177
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
178 par.DbType = DbType.AnsiStringFixedLength;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
179 par.Value = value;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
180 par.Size = value.Length;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
181 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
182
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
183 #region "smart" input-output parameter detection
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
184 if (commandType == CommandType.StoredProcedure && IsInOutParameterEmulation)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
185 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
186 var iParameterName = GetInputParameterName(par.ParameterName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
187 var fakeIOParameter = GetParameter(iParameterName, commandParameters);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
188
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
189 if (fakeIOParameter != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
190 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
191 fakeIOParameter.Value = par.Value;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
192
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
193 // direction should be output, or parameter mistmath for procedure exception
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
194 // would be thrown
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
195 par.Direction = ParameterDirection.Output;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
196
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
197 // direction should be Input
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
198 fakeIOParameter.Direction = ParameterDirection.Input;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
199 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
200 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
201 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
202 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
203
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
204 base.PrepareCommand(ref commandType, ref commandText, ref commandParameters);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
205 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
206
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
207 public override bool InitParameter(IDbDataParameter parameter)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
208 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
209 if (parameter.Value is bool)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
210 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
211 var value = (bool) parameter.Value ? "1" : "0";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
212
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
213 parameter.DbType = DbType.AnsiString;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
214 parameter.Value = value;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
215 parameter.Size = value.Length;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
216 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
217 else if (parameter.Value is Guid)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
218 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
219 var value = parameter.Value.ToString();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
220
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
221 parameter.DbType = DbType.AnsiStringFixedLength;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
222 parameter.Value = value;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
223 parameter.Size = value.Length;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
224 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
225
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
226 return base.InitParameter(parameter);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
227 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
228
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
229 public override void Configure(NameValueCollection attributes)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
230 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
231 var inOutInputParameterPrefix = attributes["InOutInputParameterPrefix"];
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
232 if (inOutInputParameterPrefix != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
233 InOutInputParameterPrefix = inOutInputParameterPrefix;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
234
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
235 var returnParameterName = attributes["ReturnParameterName"];
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
236 if (returnParameterName != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
237 ReturnParameterName = returnParameterName;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
238
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
239 var isReturnValueEmulation = attributes["IsReturnValueEmulation"];
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
240 if (isReturnValueEmulation != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
241 IsReturnValueEmulation = Common.Convert.ToBoolean(isReturnValueEmulation);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
242
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
243 var isInOutParameterEmulation = attributes["IsInOutParameterEmulation"];
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
244 if (isInOutParameterEmulation != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
245 IsInOutParameterEmulation = Common.Convert.ToBoolean(isInOutParameterEmulation);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
246
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
247 var quoteIdentifiers = attributes["QuoteIdentifiers"];
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
248 if (quoteIdentifiers != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
249 QuoteIdentifiers = Common.Convert.ToBoolean(quoteIdentifiers);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
250
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
251 base.Configure(attributes);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
252 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
253 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
254
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
255 #region FbDataReaderEx
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
256 public override IDataReader GetDataReader(MappingSchema schema, IDataReader dataReader)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
257 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
258 return
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
259 dataReader is FbDataReader
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
260 ? new FbDataReaderEx((FbDataReader) dataReader)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
261 : base.GetDataReader(schema, dataReader);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
262 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
263
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
264 private class FbDataReaderEx : DataReaderBase<FbDataReader>, IDataReader
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
265 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
266 public FbDataReaderEx(FbDataReader rd) : base(rd)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
267 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
268 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
269
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
270 #region IDataReader Members
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
271 public new object GetValue(int i)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
272 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
273 var value = DataReader.GetValue(i);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
274
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
275 if (value is DateTime)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
276 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
277 var dt = (DateTime) value;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
278
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
279 if (dt.Year == 1970 && dt.Month == 1 && dt.Day == 1)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
280 return new DateTime(1, 1, 1, dt.Hour, dt.Minute, dt.Second, dt.Millisecond);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
281 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
282
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
283 return value;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
284 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
285
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
286 public new DateTime GetDateTime(int i)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
287 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
288 var dt = DataReader.GetDateTime(i);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
289
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
290 if (dt.Year == 1970 && dt.Month == 1 && dt.Day == 1)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
291 return new DateTime(1, 1, 1, dt.Hour, dt.Minute, dt.Second, dt.Millisecond);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
292
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
293 return dt;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
294 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
295 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
296 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
297 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
298
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
299 #region FbMappingSchema
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
300 public class FbMappingSchema : FirebirdMappingSchema
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
301 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
302 protected override object MapInternal(InitContext initContext)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
303 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
304 var dr = initContext.SourceObject as FbDataReader;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
305
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
306 // Fb's SP returns single row with nulls if selected object doesn't exists
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
307 // so for all DBNull's (null) should be returned, instead of object instance
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
308 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
309 if (dr != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
310 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
311 var i = dr.FieldCount;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
312 while (--i >= 0)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
313 if (!dr.IsDBNull(i))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
314 break;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
315
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
316 // All field are DBNull.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
317 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
318 if (i < 0)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
319 return null;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
320 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
321 return base.MapInternal(initContext);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
322 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
323 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
324 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
325 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
326 }