Я довольно давно уже работаю с Firebird в Visual Studio и хочу поделится с вами примером кода который я постоянно использую, ну возможно с небольшими вариациями. По моему мнению код выглядит достаточно красиво.
Для новичков я расскажу как создать консольное приложение с использованием Firebird:
1. Создаем новое простое консольное приложение. По-умолчанию его код будет выглядеть так:
3. Указываем файл Firebird. Его можно скачать с сайта Firebirdsql.org
4. Дописываем в секции using код:
using FirebirdSql.Data.FirebirdClient;
5. Дописываем код main, так чтобы он принял вид:
Для новичков я расскажу как создать консольное приложение с использованием Firebird:
1. Создаем новое простое консольное приложение. По-умолчанию его код будет выглядеть так:
2. Добавляем ссылку на сборку Firebird:
4. Дописываем в секции using код:
using FirebirdSql.Data.FirebirdClient;
5. Дописываем код main, так чтобы он принял вид:
Code Snippet
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Data;
- using System.Text;
- using FirebirdSql.Data.FirebirdClient;
- namespace ConsoleApplication1
- {
- class Program
- {
- static void Main(string[] args)
- {
- // Строка подключения
- string ConStr = ""; // ваша строка подключения
- using (FbConnection fbc = new FbConnection(ConStr))
- {
- try
- {
- fbc.Open();
- }
- catch (Exception ex)
- {
- Console.WriteLine(ex.Message,
- System.IO.Path.GetFileName(
- System.Reflection.Assembly.GetExecutingAssembly().Location));
- return;
- }
- // Транзакция
- FbTransactionOptions fbto = new FbTransactionOptions();
- fbto.TransactionBehavior = FbTransactionBehavior.NoWait |
- FbTransactionBehavior.ReadCommitted |
- FbTransactionBehavior.RecVersion;
- FbTransaction fbt = fbc.BeginTransaction(fbto);
- // Создаем простой запрос
- string SQL = "select * from myTable Where Speed=@Speed";
- FbCommand fbcom = new FbCommand(SQL, fbc, fbt);
- fbcom.Parameters.Clear();
- fbcom.Parameters.AddWithValue("Speed", 100);
- // Создаем адаптер данных
- FbDataAdapter fbda = new FbDataAdapter(fbcom);
- DataSet ds = new DataSet();
- try
- {
- fbda.Fill(ds);
- }
- catch (Exception ex)
- {
- Console.WriteLine(ex.Message,
- System.IO.Path.GetFileName(
- System.Reflection.Assembly.GetExecutingAssembly().Location));
- return;
- }
- finally
- {
- fbt.Rollback();
- fbc.Close();
- }
- DataTable dt = ds.Tables[0];
- if (dt.Rows.Count == 0) return;
- for (int i = 0; i < dt.Rows.Count; i++)
- {
- DataRow dr = dt.Rows[i];
- if (dr.IsNull("ID") == false)
- {
- // необходимые действия
- Int32 id = Convert.ToInt32(dr["ID"]);
- }
- }
- }
- }
- }
- }
6. Разбор полетов:
6.1 Этот пример не будет работать пока переменной ConStr не будет присвоена реальная строка подключения к базе данных.
6.2 В этом коде предусмотрен блок try-catch при подключении к базе. В случае невозможности установки соединения, программа или текущий метод завершится.
6.3 Блок кода заключен в блок using, что гарантирует высвобождение ресурсов.
6.4 Второй аргумент в методе WriteLine выводит имя текущего файла.
6.5 После подключения начинается транзакция с указанными параметрами.
6.6 Для получения данных через DataSet используется адаптер данных, однако есть возможность использовать FbDataReader, но мне кажется при работе с большими выходными наборами лучше использовтаь именно адаптер данных. Т.к.сразу после заполнения данных адаптером, соединение с базой данных можно закрыть.
6.7 В качестве примера я привел SQL код с одним параметром Speed.
6.8 После любого (ошибочного иди верного) выполнения команды Fill адаптера данных транзакция откатывается и соединение закрывается.
6.9 Возможно после сообщений об ошибках вам будет удобнее добавить команду Console.ReadLin();
Вот такой пример работы с Firebird на базе оператора Select.