пятница, 23 декабря 2011 г.

Красивый код Firebird в Visual Studio 2010 (оператор Select)

Я довольно давно уже работаю с Firebird в Visual Studio и хочу поделится с вами примером кода который я постоянно использую, ну возможно с небольшими вариациями. По моему мнению код выглядит достаточно красиво.


Для новичков я расскажу как создать консольное приложение с использованием Firebird:


1. Создаем новое простое консольное приложение. По-умолчанию его код будет выглядеть так:




2. Добавляем ссылку на сборку Firebird:




3. Указываем файл Firebird. Его можно скачать с сайта Firebirdsql.org




4. Дописываем в секции using код:
using FirebirdSql.Data.FirebirdClient;






5. Дописываем код main, так чтобы он принял вид: 

Code Snippet
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Data;
  5. using System.Text;
  6. using FirebirdSql.Data.FirebirdClient;
  7.  
  8. namespace ConsoleApplication1
  9. {
  10.     class Program
  11.     {
  12.         static void Main(string[] args)
  13.         {
  14.             // Строка подключения
  15.             string ConStr = ""; // ваша строка подключения
  16.             using (FbConnection fbc = new FbConnection(ConStr))
  17.             {
  18.                 try
  19.                 {
  20.                     fbc.Open();
  21.                 }
  22.                 catch (Exception ex)
  23.                 {
  24.                     Console.WriteLine(ex.Message,
  25.                         System.IO.Path.GetFileName(
  26.                         System.Reflection.Assembly.GetExecutingAssembly().Location));
  27.                     return;
  28.                 }
  29.  
  30.                 // Транзакция
  31.                 FbTransactionOptions fbto = new FbTransactionOptions();
  32.                 fbto.TransactionBehavior = FbTransactionBehavior.NoWait |
  33.                      FbTransactionBehavior.ReadCommitted |
  34.                      FbTransactionBehavior.RecVersion;
  35.                 FbTransaction fbt = fbc.BeginTransaction(fbto);
  36.  
  37.                 // Создаем простой запрос
  38.                 string SQL = "select * from myTable Where Speed=@Speed";
  39.                 FbCommand fbcom = new FbCommand(SQL, fbc, fbt);
  40.                 fbcom.Parameters.Clear();
  41.                 fbcom.Parameters.AddWithValue("Speed", 100);
  42.  
  43.                 // Создаем адаптер данных
  44.                 FbDataAdapter fbda = new FbDataAdapter(fbcom);
  45.  
  46.                 DataSet ds = new DataSet();
  47.  
  48.                 try
  49.                 {
  50.                     fbda.Fill(ds);
  51.                 }
  52.                 catch (Exception ex)
  53.                 {
  54.                     Console.WriteLine(ex.Message,
  55.                         System.IO.Path.GetFileName(
  56.                         System.Reflection.Assembly.GetExecutingAssembly().Location));
  57.                     return;
  58.                 }
  59.                 finally
  60.                 {
  61.                     fbt.Rollback();
  62.                     fbc.Close();
  63.                 }
  64.  
  65.                 DataTable dt = ds.Tables[0];
  66.  
  67.                 if (dt.Rows.Count == 0) return;
  68.                 for (int i = 0; i < dt.Rows.Count; i++)
  69.                 {
  70.                     DataRow dr = dt.Rows[i];
  71.  
  72.                     if (dr.IsNull("ID") == false)
  73.                     {
  74.                         // необходимые действия
  75.                         Int32 id = Convert.ToInt32(dr["ID"]);
  76.                         
  77.                     }
  78.                 }
  79.             }
  80.         }
  81.     }
  82. }






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.