Сведения о вопросе

FUTER

03:30, 8th August, 2020

Теги

SQLite   C#    

C# + sqlite, несколько вопросов

Просмотров: 378   Ответов: 1

В моем предыдущем вопросе я спрашивал насчёт языка, и вот решил начать писать прогу на C#

Но так как язык для меня новый сразу возникли некоторые вопросы. Какие-то решил с помощью гугля, а вот с базой данных возникла проблема.

Подключаю sqlite через ADO.NET (http://sqlite.phxsoftware.com/)
Через VS создаю таблицу users, заливаю туда какую-то инфу чтобы её вывести.
На форму кидаю элемент GridView.
Затем пользуясь этим руководством, пишу:

private void Form1_Load(object sender, EventArgs e)

{

            SQLiteConnection ObjConnection = new SQLiteConnection("Data Source=data/database.db3;");

            SQLiteCommand ObjCommand = new SQLiteCommand("SELECT * FROM users", ObjConnection);

            ObjCommand.CommandType = CommandType.Text;

            SQLiteDataAdapter ObjDataAdapter = new SQLiteDataAdapter(ObjCommand);

            DataSet dataSet = new DataSet();

            ObjDataAdapter.Fill(dataSet, "users");

            dataGridView1.DataSource = dataSet.Tables["users"];

        }


И всё отлично работает, при загрузке программы появляются данные из базы. Но дело не в этом. Я хочу провести небольшой рефакторинг:

— Нужно устанавливать связь с базой данных при открытии программы. Как я понял, за это отвечает первая строка (ObjConnection = new SQLiteConnection). Куда это лучше перенести?
— Где и как лучше хранить это соединение с базой, чтобы я всегда смог получить к нему доступ (что-то типа глобальной переменной)?
— Как мне сделать запрос, который вытащит одну строку, чтобы в дальнейшем с ней работать? Нужно что-то типа ObjConnection.query(«SELECT login FROM users WHERE id = 1»)
— В панели элементов появилась вкладка SQLite с элементами Connection, DataAdapter, Command — для чего они нужны? Чтобы визуально настроить базу через них, не прописывая это в коде?



  Сведения об ответе

Chhiki

09:34, 25th August, 2020

>> Нужно устанавливать связь с базой данных при открытии программы. Как я понял, за это отвечает первая строка (ObjConnection = new SQLiteConnection). Куда это лучше перенести?
Вообще обычно для таких целей создаётся уровень доступа к данным, отдельный от уровня представления, который инкапсулирует в себе всю логику по управлению запросами к бд (гуглить «n-tier application»). Держать постоянно открытым одно подключение — не самый лучший вариант. Но к сожалению, не могу сказать, как обстоят дела с кэшированием подключений в этом sqlite-провайдере, тут уже надо тестировать.

>> Где и как лучше хранить это соединение с базой, чтобы я всегда смог получить к нему доступ (что-то типа глобальной переменной)?
Для десктопных приложений — стандартный конфигурационный файл app.config (задать значения для строк подключений можно через Project Settings -> Settings, у записи указываете scope = Application, тогда её значение доступно через %namespace%.Properties.Settings)

>> Как мне сделать запрос, который вытащит одну строку, чтобы в дальнейшем с ней работать? Нужно что-то типа ObjConnection.query(«SELECT login FROM users WHERE id = 1»)
ExecuteReader()


Ответить на вопрос

Чтобы ответить на вопрос вам нужно войти в систему или зарегистрироваться