Каков наилучший способ подключения и использования базы данных sqlite из C # - PullRequest
41 голосов
/ 25 августа 2008

Я делал это раньше в C ++, включив sqlite.h, но есть ли такой же простой способ в C #?

Ответы [ 8 ]

66 голосов
/ 10 августа 2009

Я с Брюсом. Я использую http://system.data.sqlite.org/ также с большим успехом. Вот простой пример класса, который я создал:

using System;
using System.Text;
using System.Data;
using System.Data.SQLite;

namespace MySqlLite
{
      class DataClass
      {
        private SQLiteConnection sqlite;

        public DataClass()
        {
              //This part killed me in the beginning.  I was specifying "DataSource"
              //instead of "Data Source"
              sqlite = new SQLiteConnection("Data Source=/path/to/file.db");

        }

        public DataTable selectQuery(string query)
        {
              SQLiteDataAdapter ad;
              DataTable dt = new DataTable();

              try
              {
                    SQLiteCommand cmd;
                    sqlite.Open();  //Initiate connection to the db
                    cmd = sqlite.CreateCommand();
                    cmd.CommandText = query;  //set the passed query
                    ad = new SQLiteDataAdapter(cmd);
                    ad.Fill(dt); //fill the datasource
              }
              catch(SQLiteException ex)
              {
                    //Add your exception code here.
              }
              sqlite.Close();
              return dt;
  }
}

Существует также пакет NuGet: System.Data.SQLite .

41 голосов
/ 25 августа 2008

Поставщик ADO.NET 2.0 для SQLite загружает более 200 раз в день, поэтому я думаю, что вы можете безопасно использовать его.

12 голосов
/ 27 августа 2008

Я использовал это с большим успехом:

http://system.data.sqlite.org/

Бесплатно без ограничений.

(примечание к обзору: исходного сайта больше не существует. Приведенная выше ссылка содержит ссылку на сайт 404 и содержит всю информацию об оригинале)

- Bruce

6 голосов
/ 25 августа 2008

Список оболочек Sqlite для .Net на http://www.sqlite.org/cvstrac/wiki?p=SqliteWrappers., как я слышал, вполне хорош. Этот конкретный позволяет вам получить доступ к Sqlite через ADO.Net, как и любая другая база данных.

5 голосов
/ 20 июня 2013

https://github.com/praeclarum/sqlite-net теперь, вероятно, лучший вариант.

5 голосов
/ 07 августа 2009

Также теперь есть эта опция: http://code.google.com/p/csharp-sqlite/ - полный порт SQLite для C #.

3 голосов
/ 29 августа 2012

Другим способом использования базы данных SQLite в NET Framework является использование Fluent-NHibernate .
[Это модуль NET, который охватывает NHibernate (модуль ORM - Object Relational Mapping) и позволяет программно конфигурировать NHibernate (без файлов XML) с плавным шаблоном.]

Вот краткое описание «Как начать», как сделать это в C # шаг за шагом:

https://github.com/jagregory/fluent-nhibernate/wiki/Getting-started

Содержит исходный код в виде проекта Visual Studio.

1 голос
/ 26 июля 2012

Mono поставляется с оберткой, используйте их!

https://github.com/mono/mono/tree/master/mcs/class/Mono.Data.Sqlite/Mono.Data.Sqlite_2.0 дает код для переноса действительной библиотеки SQLite (http://www.sqlite.org/sqlite-shell-win32-x86-3071300.zip, найденной на странице загрузки http://www.sqlite.org/download.html/) в .net дружественном виде. Работает на Linux или Windows.

Это кажется самым тонким из всех миров, сводя к минимуму вашу зависимость от сторонних библиотек. Если бы мне пришлось делать этот проект с нуля, я бы так и сделал.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...