3 // Ben Motmans <ben.motmans@gmail.com>
5 // Copyright (c) 2007 Ben Motmans
7 // Permission is hereby granted, free of charge, to any person obtaining a copy
8 // of this software and associated documentation files (the "Software"), to deal
9 // in the Software without restriction, including without limitation the rights
10 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11 // copies of the Software, and to permit persons to whom the Software is
12 // furnished to do so, subject to the following conditions:
14 // The above copyright notice and this permission notice shall be included in
15 // all copies or substantial portions of the Software.
17 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
28 using System
.Collections
.Generic
;
29 using Mono
.Data
.Sqlite
;
31 namespace MonoDevelop
.Database
.Sql
.Sqlite
33 public class SqlitePooledDbConnection
: AbstractPooledDbConnection
35 public SqlitePooledDbConnection (IConnectionPool connectionPool
, IDbConnection connection
)
36 : base (connectionPool
, connection
)
40 public override Version DatabaseVersion
{
42 SqliteConnection connection
= DbConnection
as SqliteConnection
;
44 //the same output as sqlite3_libversion
45 //eg: #define SQLITE_VERSION "3.5.3"
46 return new Version (connection
.ServerVersion
);
48 return new Version (3, 0);
53 public override DataSet
ExecuteSet (IDbCommand command
)
56 throw new ArgumentException ("command");
58 DataSet
set = new DataSet ();
60 using (SqliteDataAdapter adapter
= new SqliteDataAdapter (command
as SqliteCommand
)) {
63 } catch (Exception e
) {
64 QueryService
.RaiseException (e
);
71 public override DataTable
ExecuteTable (IDbCommand command
)
74 throw new ArgumentException ("command");
76 DataTable table
= new DataTable ();
78 using (SqliteDataAdapter adapter
= new SqliteDataAdapter (command
as SqliteCommand
)) {
81 } catch (Exception e
) {
82 QueryService
.RaiseException (e
);
89 public override DataTable
GetSchema (string collectionName
, params string[] restrictionValues
)
91 return (connection
as SqliteConnection
).GetSchema (collectionName
, restrictionValues
);