Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.79/29: Рейтинг темы: голосов - 29, средняя оценка - 4.79
130 / 68 / 31
Регистрация: 24.07.2018
Сообщений: 787

Поиск в базе данных SQLite

05.04.2019, 10:06. Показов 5603. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Подскажите пожалуйста. Создаю программу для рассылки почты по заказчикам. Интересует как вытаскивать данные напрямую из базы данных при открытом подключении.
Суть задачи:
1. Открываю соединение с базой данных

2. Необходимо вытащить в какую нибудь переменную все Номера счета через запятую (столбец Номер счета) для Заказчик 1 (столбец Код заказчика) со статусом отправки - не отправлен(т.е. столбец Статус отправки письма, где пустое значение)

3. Со скрина получается например НекаяПеременная = сч 1113, сч 1133, сч 1134, сч 1135, сч 1156

4. Закрываю соединение с базой данных.

Как это все организовать?
Можно конечно DataGridView перебрать в поиске данных.Но мне надо напрямую из базы.
Спасибо тем кто ответит.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.04.2019, 10:06
Ответы с готовыми решениями:

C# + SQLite. Как организовать UNION баз разных данных (не таблиц в одной базе данных)
Работая с SQLite Studio я заметил, что если законектить 2е разные базы данных с одинаковой структурой(столбцы и их название) затем в...

SQLite отслеживать изменения в базе данных
Приветствую. Опишу суть, необходимо отследить вносимые изменения в базу данных из разных программ то есть изменения вносит одно приложение...

SQLite. Как из двух записей в базе данных сделать третью, используя только SQL?
Есть Два поля: Индекс и Дата, оба хранятся как varchar(50), оба не равны нулю какой должен быть запрос, чтобы при занесении в таблицу...

12
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
05.04.2019, 10:09
Вот тут почитайте, там и пример есть: https://www.cyberforum.ru/ado-... 59529.html
0
130 / 68 / 31
Регистрация: 24.07.2018
Сообщений: 787
05.04.2019, 10:17  [ТС]
Почтальон, Не понимаю как оно связано с моим случаем
0
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
05.04.2019, 10:18
MaksimkaI, используйте EF для работы с БД
0
130 / 68 / 31
Регистрация: 24.07.2018
Сообщений: 787
05.04.2019, 10:28  [ТС]
Почтальон, Куча непонятных настроек, мне и так sql в новинку. чем все это плохо?)
C#
1
2
3
4
5
6
7
8
            SQLiteConnection connect = new SQLiteConnection("Data Source=DataBase.db;Version=3;");
            connect.Open();
            SQLiteDataAdapter dataAdapter = new SQLiteDataAdapter("Select * from Регистрация", connect);
            DataSet ds = new DataSet();
            dataAdapter.Fill(ds);
            dgvBase.DataSource = ds;
            dgvBase.DataMember = ds.Tables[0].ToString();
            connect.Close();
я Думаю как и обычно работать это можно реализовать.
0
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
05.04.2019, 10:39
Цитата Сообщение от MaksimkaI Посмотреть сообщение
чем все это плохо?)
Это не плохо, "внутренности" все-таки нужно знать. Но время не стоит на месте, процессы развиваются. Поэтому лучше, и проще, использовать EF, чем вручную писать все запросы.
0
130 / 68 / 31
Регистрация: 24.07.2018
Сообщений: 787
05.04.2019, 10:42  [ТС]
Почтальон, Вот мне внутренности и надо до конца изучить, если перейду на entity я не буду знать как все это все делается(
0
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
05.04.2019, 10:43
Ок, тогда курите подключаемый уровень ado.net
0
130 / 68 / 31
Регистрация: 24.07.2018
Сообщений: 787
05.04.2019, 10:49  [ТС]
Почтальон, так вот вопрос может подскажете как это без EF сделать. Хотелось бы на прямую с базой работать, потому что в будущем более сложную программу писать, где данные могут восполняться, пока я что то ищу допустим в DGV или DataTable. Допустим пока я ищу все готовые заказы, может проштриховаться новый заказ, то что он готов. Поэтому нужна необходимость работы в реальном времени, а не с копией базы. Под копией я понимаю, вот информация в DGV обновилась и все, данные через две секунды в DGV уже не актуальные, т.к. через секунду добавилась новая запись о готовности заказа.

Добавлено через 1 минуту
Почтальон, а я думал что такое Entity Freamfork). теперь понятно для чего
0
Эксперт .NET
 Аватар для Usaga
14145 / 9374 / 1350
Регистрация: 21.01.2016
Сообщений: 35,306
05.04.2019, 11:27
MaksimkaI, ADO.NET, SQL.
0
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
05.04.2019, 11:27
Ну так у DGV сделаете контекс данных вашей бд, и будете работать "напрямую", только нужно через модель делать, а не хранить данные в элементах. Если хотите напрямую работать с БД, курите язык запросов SQL
0
999 / 358 / 135
Регистрация: 27.10.2006
Сообщений: 764
05.04.2019, 15:32
MaksimkaI,

1. Запросом нужно получать из базы не все записи, как вы делаете сейчас, а лишь те, где в поле "Статус отправки письма" пустой

то есть не
C#
1
 SQLiteDataAdapter dataAdapter = new SQLiteDataAdapter("Select * from Регистрация", connect);
а что-то вроде
C#
1
 SQLiteDataAdapter dataAdapter = new SQLiteDataAdapter("Select [номер счёта] from Регистрация Where [Статус отправки письма] IS NULL, connect);
или
C#
1
Where [Статус отправки письма] = ""
2. Полученные записи можете выгружать в DataTable, а не в DataSet, то есть вместо

C#
1
2
DataSet ds = new DataSet();
dataAdapter.Fill(ds);
пишите

C#
1
2
DataTable dt = new DataTable();
dataAdapter.Fill(dt);
3. Циклом проходите по всем строкам dt и получайте номера счетов

C#
1
2
3
4
 foreach (DataRow dr in dt)
   {
        string schet = dr["номер счёта"].ToString();
   }
0
130 / 68 / 31
Регистрация: 24.07.2018
Сообщений: 787
05.04.2019, 16:50  [ТС]
Pavel55, Так и сделал. Спасибо за ответ.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
                //Формируем таблицу не разосланных заказов для customerName
                adapter = new SQLiteDataAdapter("SELECT * FROM [Регистрация] WHERE  [Код заказчика] = '" + customerName + "' AND [Отправлен] is NULL ", connect);
                table = new DataTable();
                adapter.Fill(table);
                
                                
                // Формируем лист для конкретного заказчика
                foreach (DataRow row in table.Rows)
                    {
                        list.Add(row["Серия"].ToString());
                        listВизуализация.Items.Add(row["Номер счета"].ToString());
                        mailBody = mailBody + "\n" + row["Серия"].ToString() + "-" +row["Номер счета"].ToString();
                    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.04.2019, 16:50
Помогаю со студенческими работами здесь

Поиск по базе данных Sqlite
Здравствуйте, возникла следующая проблема - не могу реализовать поиск по базе данных, чтобы в lineEdit вводить значения и последующее...

Qt и SQLite. Поиск в базе данных
Привет всем!!!Пишу программку.Работаю с SQite.Надкнулся на проблемку.Осуществляю поиск имен из базы данных.Я в лайнэдите пишу первые буквы...

Поиск по базе SQLite
Добрый день! С SQLite работаю в первый раз ,никак не могу разобраться.Суть кода:при нажатии на кнопку идет выборка из SQLite бд ,если такой...

Searchview. Поиск по базе SQLite
Здравствуйте. Не могу разобраться с этим поиском. Хотя бы один рабочий пример. То, что я находил - не запускалось в моей среде разработки....

Поиск уникальных элементов в базе SQLite
Здравствуйте. Вот у меня имеется такой вот код: cursor = mDb.rawQuery("SELECT * FROM имя_таблицы where поле_таблицы = ?", new...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru