MyTetra Share
Делитесь знаниями!
Как работать с SQLite в C#
Время создания: 04.09.2019 18:55
Текстовые метки: SQLite, c#, Базы данных, БД,
Раздел: Компьютер - C# - SQLite
Запись: Kozlov-AE/Tetra/master/base/1565534025ble6yhwhnc/text.html на raw.githubusercontent.com

Рассмотрим основные методы работы с базой данных SQLite: SELECT, CREATE, INSERT, UPDATE, DELETE. Чтобы материал не был обыденным мы рассмотрим добавление изображений и файлов в базу данных SQLite, а также их чтение из базы данных.

Сразу хочу сказать, что синтаксис похож на запросы MS SQL, а также подключение к базе данных происходит аналогично. Поэтому если вы работаете в C# с базами MS SQL, то вы прямо сейчас уже сможете самостоятельно работать с SQLite немного изменив свои запросы в коде.

Для работы с SQLite нам необходимо к проекту подключить пять NuGet пакетов, которые показаны на картинке:

Однако достаточно подключить один пакет, который выделен на картинке, и остальные пакеты подтянутся и установятся автоматически.

Прописываем для работы с SQLite:

C#


1

2

using System.Data.SQLite;

 

Дополнительно к проекту подключаем:

C#


1

2

3

4

5

6

using System;

using System.IO;

using System.Drawing;

using System.Diagnostics;

using System.Collections.Generic;

 

Далее по тексту будет код без методов, который вы прописываете у себя в нужных вам методах.

Создание базы данных SQLite

C#


1

2

3

4

5

if (!File.Exists(@"C:\TestDB.db")) // если базы данных нету, то...

{

SQLiteConnection.CreateFile(@"C:\TestDB.db); // создать базу данных, по указанному пути содаётся пустой файл базы данных

}

 

Создание таблицы в базе данных SQLite

Создадим таблицу, с которой будем в дальнейшем работать.

C#


1

2

3

4

5

6

7

8

9

10

11

using (SQLiteConnection Connect = new SQLiteConnection(@"Data Source=C:\TestDB.db; Version=3;")) // в строке указывается к какой базе подключаемся

{

// строка запроса, который надо будет выполнить

string commandText = "CREATE TABLE IF NOT EXISTS [dbTableName] ( [id] INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, [image] BLOB, [image_format] VARCHAR(10), " +

"[image_name] NVARCHAR(128), [file] BINARY, [file_format] VARCHAR(10), [file_name] NVARCHAR(128))"; // создать таблицу, если её нет

SQLiteCommand Command = new SQLiteCommand(commandText, Connect);

Connect.Open(); // открыть соединение

Command.ExecuteNonQuery(); // выполнить запрос

Connect.Close(); // закрыть соединение

}

 

Добавление изображения в базу данных SQLite

C#


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

// Конвертируем изображение в байты byte[]

string imgPath = @"C:\image-01.png"; // изображение

FileInfo _imgInfo = new FileInfo(imgPath);

long _numBytes = _imgInfo.Length;

FileStream _fileStream = new FileStream(imgPath, FileMode.Open, FileAccess.Read); // читаем изображение

BinaryReader _binReader = new BinaryReader(_fileStream);

byte[] _imageBytes = _binReader.ReadBytes((int)_numBytes); // изображение в байтах

 

string imgFormat = Path.GetExtension(imgPath).Replace(".", "").ToLower(); // запишем в переменную расширение изображения в нижнем регистре, не забыв удалить точку перед расширением, получим «png»

string imgName = Path.GetFileName(imgPath).Replace(Path.GetExtension(imgPath), ""); // запишем в переменную имя файла, не забыв удалить расширение с точкой, получим «image-01»

 

// записываем информацию в базу данных

using (SQLiteConnection Connect = new SQLiteConnection(@"Data Source=C:\TestDB.db; Version=3;"))

{

// в запросе есть переменные, они начинаются на @, обратите на это внимание

string commandText = "INSERT INTO [dbTableName] ([image], [image_format], [image_name]) VALUES(@image, @format, @name)";

SQLiteCommand Command = new SQLiteCommand(commandText, Connect);

Command.Parameters.AddWithValue("@image", _imageBytes); // присваиваем переменной значение

Command.Parameters.AddWithValue("@format", imgFormat);

Command.Parameters.AddWithValue("@name", imgName);

Connect.Open();

Command.ExecuteNonQuery();

Connect.Close();

}

 

Извлечение изображения из базы данных SQLite

C#


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

// получаем данные их БД

// сделав запрос к БД мы получим множество строк в ответе, поэтому мы их записываем в массивы/List

List<byte[]> _imageList = new List<byte[]>(); // изображение в байтах

List<string> _imgFormatList = new List<string>(); // расширения изображений

 

using (SQLiteConnection Connect = new SQLiteConnection(@"Data Source=C:\TestDB.db; Version=3;"))

{

Connect.Open();

SQLiteCommand Command = new SQLiteCommand

{

Connection = Connect,

CommandText = @"SELECT * FROM [dbTableName] WHERE [image_format] NOT NULL" // выборка записей с заполненной ячейкой формата изображения, можно другой запрос составить

};

SQLiteDataReader sqlReader = Command.ExecuteReader();

byte[] _dbImageByte = null;

string _dbImageFormat = null;

while (sqlReader.Read()) // считываем и вносим в лист все параметры

{

_dbImageByte = (byte[])sqlReader["image"]; // читаем строки с изображениями, которые хранятся в байтовом формате

_imageList.Add(_dbImageByte); // добавляем в List

_dbImageFormat = sqlReader["image_format"].ToString().TrimStart().TrimEnd(); // читаем строки с форматом изображений

_imgFormatList.Add(_dbImageFormat); // добавляем в List

}

Connect.Close();

}

 

if (_imageList.Count == 0) // если в базе нет записей с изображениями (пустой список), то...

{

return; // завершить работу метода

}

 

// конвертируем бинарные данные в изображение

byte[] _imageBytes = _imageList[0]; // так как SQLite вернёт список изображений из БД, то из листа берём первое с индексом '0'

MemoryStream ms = new MemoryStream(_imageBytes);

Image _newImg = Image.FromStream(ms);

 

// сохраняем изоражение на диск

string _imgFormat = _imgFormatList[0]; // получаем расширение текущего изображения хранящееся в БД

string _newImageSaved = @"C:\image-02." + _imgFormat; // задаём путь сохранения и имя нового изображения

if (_imgFormat == "jpeg" || _imgFormat == "jpg") // если расширение равно указанному, то...

_newImg.Save(_newImageSaved, System.Drawing.Imaging.ImageFormat.Jpeg); // задаём указанный формат: ImageFormat

else if (_imgFormat == "png")

_newImg.Save(_newImageSaved, System.Drawing.Imaging.ImageFormat.Png);

else if (_imgFormat == "bmp")

_newImg.Save(_newImageSaved, System.Drawing.Imaging.ImageFormat.Bmp);

else if (_imgFormat == "gif")

_newImg.Save(_newImageSaved, System.Drawing.Imaging.ImageFormat.Gif);

else if (_imgFormat == "ico")

_newImg.Save(_newImageSaved, System.Drawing.Imaging.ImageFormat.Icon);

else if (_imgFormat == "tiff" || _imgFormat == "tif")

_newImg.Save(_newImageSaved, System.Drawing.Imaging.ImageFormat.Tiff);

// и т.д., можно все if заменить на одну строку "_newImg.Save(_newImageSaved)", насколько это правильно сказать не могу, но работает

 

Добавление любого файла в базу данных SQLite

C#


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

// Конвертируем файл в байты byte[]

byte[] _fileBytes = null;

string filePath = @"C:\music-01.mp3"; // файл

FileInfo _fileInfo = new FileInfo(filePath);

long _numBytes = _fileInfo.Length;

FileStream _fileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read); // откроем файл на чтение

BinaryReader _binReader = new BinaryReader(_fileStream);

_fileBytes = _binReader.ReadBytes((int)_numBytes); // файл в байтах

 

string fileFormat = Path.GetExtension(filePath).Replace(".", "").ToLower(); // запишем в переменную расширение файла в нижнем регистре, не забыв удалить точку перед расширением, получим «mp3»

string fileName = Path.GetFileName(filePath).Replace(Path.GetExtension(filePath), ""); // запишем в переменную имя файла, не забыв удалить расширение с точкой, получим «music-01»

 

// записываем информацию в базу данных

using (SQLiteConnection Connect = new SQLiteConnection(@"Data Source=C:\TestDB.db; Version=3;"))

{

string commandText = "INSERT INTO [dbTableName] ([file], [file_format], [file_name]) VALUES(@file, @format, @name)";

SQLiteCommand Command = new SQLiteCommand(commandText, Connect);

Command.Parameters.AddWithValue("@file", _fileBytes);

Command.Parameters.AddWithValue("@format", fileFormat);

Command.Parameters.AddWithValue("@name", fileName);

Connect.Open();

Command.ExecuteNonQuery();

Connect.Close();

}

 

Извлечение файла из базы данных SQLite

Комментариев в коде в начале будет минимум, так как здесь код аналогичный коду извлечения изображения из базы данных, а вот вторая часть кода отличается.

C#


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

// получаем данные их БД

List<byte[]> _fileList = new List<byte[]>();

List<string> _fileFormatList = new List<string>();

 

using (SQLiteConnection Connect = new SQLiteConnection(@"Data Source=C:\TestDB.db; Version=3;"))

{

Connect.Open();

SQLiteCommand Command = new SQLiteCommand

{

Connection = Connect,

CommandText = @"SELECT * FROM [dbTableName] WHERE [file_format] NOT NULL"

};

SQLiteDataReader sqlReader = Command.ExecuteReader();

byte[] _dbFileByte = null;

string _dbFileFormat = null;

while (sqlReader.Read())

{

_dbFileByte = (byte[])sqlReader["file"];

_fileList.Add(_dbFileByte);

_dbFileFormat = sqlReader["file_format"].ToString().TrimStart().TrimEnd();

_fileFormatList.Add(_dbFileFormat);

}

Connect.Close();

}

 

if (_fileList.Count == 0) // если в базе нет записей с файлами (пустой список), то...

{

return; // завершить работу метода

}

 

// сохранить файл на диск

byte[] _fileBytes = _fileList[0]; // получаем массив байтов файла, который в БД (первый из списка)

string _fileFormat = _fileFormatList[0]; // получаем расширение файла (первый из списка)

string _newFileSaved = @"C:\music-01." + _fileFormat; // задаём путь сохранения файла с именем и расширение

FileStream fileStream = new FileStream(_newFileSaved, FileMode.Create, FileAccess.ReadWrite);

BinaryWriter binWriter = new BinaryWriter(fileStream);

binWriter.Write(_fileBytes);

binWriter.Close();

 

С помощью кода добавления и извлечения файла можно писать и считывать из базы данных любые файлы включая изображения.

Обновление записи в базе данных SQLite

C#


1

2

3

4

5

6

7

8

9

10

11

12

13

using (SQLiteConnection Connect = new SQLiteConnection(@"Data Source=C:\TestDB.db; Version=3;"))

{

string commandText = "UPDATE [dbTableName] SET [file_name] = @value WHERE [id] = @id";

SQLiteCommand Command = new SQLiteCommand(commandText, Connect);

Command.Parameters.AddWithValue("@value", "Новое имя файла");

Command.Parameters.AddWithValue("@id", 1); // присваиваем переменной номер (id) записи, которую будем обновлять

Connect.Open();

// Command.ExecuteNonQuery(); // можно эту строку вместо двух последующих строк

Int32 _rowsUpdate = Command.ExecuteNonQuery(); // sql возвращает сколько строк обработано

MessageBox.Show("Обновлено строк: " + _rowsUpdate);

Connect.Close();

}

 

Удаление записи в базе данных SQLite

C#


1

2

3

4

5

6

7

8

9

10

11

12

using (SQLiteConnection Connect = new SQLiteConnection(@"Data Source=C:\TestDB.db; Version=3;"))

{

string commandText = "DELETE FROM [dbTableName] WHERE [id] = @id LIMIT 1"; // LIMIT в SQLite аналог TOP в MS SQL

SQLiteCommand Command = new SQLiteCommand(commandText, Connect);

Command.Parameters.AddWithValue("@id", textBoxDeleteData.Text);

Connect.Open();

// Command.ExecuteNonQuery(); // можно эту строку вместо двух последующих строк

Int32 _rowsUpdate = Command.ExecuteNonQuery(); // sql возвращает сколько строк обработано

MessageBox.Show("Удалено строк: " + _rowsUpdate);

Connect.Close();

}

 

Заключение

Как видим есть похожий код (DELETE и UPDATE), а есть отличающийся (SELECT сравните с другими).

 
MyTetra Share v.0.55
Яндекс индекс цитирования