Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.68/19: Рейтинг темы: голосов - 19, средняя оценка - 4.68
0 / 0 / 0
Регистрация: 20.06.2013
Сообщений: 15
SQLite

Не работает проверка существования таблицы через метод ExecuteNonQuery() из System.Data.SQLite.dll

23.09.2013, 13:57. Показов 3757. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Использую приведенный ниже метод для определения существования таблицы в БД
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public int iExecuteNonQuery(string FileData, string sSql)
{
  int n = 0;
  try
  {
      using (SQLiteConnection con = new SQLiteConnection())   //Создание экземпляра класса SQLiteConnection
      {
          con.ConnectionString = @"Data Source=" + FileData + ";New=False;Version=3"; //строка соединения c БД, где FileData путь к файлу БД, а NewDB == true создать новую, false - открыть существующую.
          con.Open();     //соединение
          using (SQLiteCommand sqlCommand = con.CreateCommand())
          {
            sqlCommand.CommandText = sSql;
            n = sqlCommand.ExecuteNonQuery(); //метод из System.Data.SQLite.dll Выполняет для подключения инструкцию Transact-SQL и возвращает количество задействованных в инструкции строк.
           }
          con.Close();
       }
  }
      catch (Exception ex)
          {
             n = 0;
           }
    return n;
}
В качестве FileData передаю полный путь к БД
А команду sSql представляет следующая строка: @"SELECT name FROM sqlite_master WHERE type = 'table' AND tbl_name = 'orders_log'"

Результат: ExecuteNonQuery() возвращает 0.
Проверяю в SQLite Expert вводя SQL запрос того же содержания выдает 1.

Меняю команду на: @"SELECT name FROM sqlite_master WHERE type = 'table' ORDER BY name" ее выполнение должно дать полное число таблиц в БД - в моем случае 7.
Результат: ExecuteNonQuery() возвращает 0.
Проверяю в SQLite Expert - все правильно 7.

Из-за этой ошибки у меня таблица создается при каждом запуске заново.

При трассировке в Visual Studio 10 вижу, что SQL запрос в метод ExecuteNonQuery() передается без ошибок и соответствующая БД открыта.

Что делаю не так? Как победить?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.09.2013, 13:57
Ответы с готовыми решениями:

Как соединить 2 таблицы с полями (System.Data.SQLite.dll)
Подскажите как можно соединить несколько полей чтобы достать данные (значений) из каждого (объединить их в одно целое и показать на консоль...

Где скачать библиотеку System.Data.SQLite.dll
Где можно это скачать? На официальном сайте для скачки предлагается архив с кучей файлов, а не отдельная библиотека. А везде в...

Ошибка An unhandled exception of type 'System.Data.OleDb.OleDbException' occurred in system.data.dll
добовляю данные в таблицу .mdb (язык C#) string strSql='INSERT INTO tt (ID,F1,F2) VALUES(?,?,?)'; OleDbConnection cn = new...

12
 Аватар для Cupko
658 / 595 / 171
Регистрация: 17.07.2012
Сообщений: 1,682
Записей в блоге: 1
23.09.2013, 14:07
ExecuteNonQuery() возвращает количество строк затронутых Insert, Update или Delete командами. Чтобы получить количество строк выборки Select используйте Count и ExecuteScalar().
0
0 / 0 / 0
Регистрация: 20.06.2013
Сообщений: 15
23.09.2013, 14:47  [ТС]
Попробовал.
Написал следующий метод:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public int CountExecuteScalar(string FileData, string sSql)
{
    int n = 0;
    try
    {
       using (SQLiteConnection con = new SQLiteConnection())   //Создание экземпляра класса SQLiteConnection
       {
          con.ConnectionString = @"Data Source=" + FileData + ";New=False;Version=3"; //строка соединения c БД
          con.Open();     //соединение
          using (SQLiteCommand sqlCommand = con.CreateCommand())
          {
              sqlCommand.CommandText = sSql;
              n = (int)sqlCommand.ExecuteScalar(); //метод из System.Data.SQLite.dll 
          }
          con.Close();
        }
    }
     catch (Exception ex)
     {
        n = 0;
     }
   return n;
}
Для строки
C#
1
n = (int)sqlCommand.ExecuteScalar();
Получил исключение
$exception {"Заданное приведение является недопустимым."} System.Exception {System.InvalidCastException}
0
 Аватар для Cupko
658 / 595 / 171
Регистрация: 17.07.2012
Сообщений: 1,682
Записей в блоге: 1
23.09.2013, 14:49
Запрос с COUNT посылаете?
0
 Аватар для m0nax
1274 / 975 / 113
Регистрация: 12.01.2010
Сообщений: 1,971
23.09.2013, 15:13
исключение потому что ExecuteScalar возвращает long (или ulong не помню)
0
0 / 0 / 0
Регистрация: 20.06.2013
Сообщений: 15
23.09.2013, 15:15  [ТС]
Sql запрос следующий: @"SELECT name FROM sqlite_master WHERE type = 'table' AND tbl_name = 'orders_log'"
0
 Аватар для Cupko
658 / 595 / 171
Регистрация: 17.07.2012
Сообщений: 1,682
Записей в блоге: 1
23.09.2013, 15:22
Цитата Сообщение от m0nax Посмотреть сообщение
исключение потому что ExecuteScalar возвращает long (или ulong не помню)
MS SQL Count возвращает int, ExecuteScalar соотв. object.
Цитата Сообщение от greg_bond Посмотреть сообщение
Sql запрос следующий: @"SELECT name FROM sqlite_master WHERE type = 'table' AND tbl_name = 'orders_log'"
SQL
1
SELECT COUNT(name) FROM sqlite_master WHERE TYPE = 'table' AND tbl_name = 'orders_log'
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
23.09.2013, 15:26
Проверяй результат на DBNull.Value, ибо его к int явно не привести (в общем случае)
0
 Аватар для Cupko
658 / 595 / 171
Регистрация: 17.07.2012
Сообщений: 1,682
Записей в блоге: 1
23.09.2013, 15:33
Цитата Сообщение от pincet Посмотреть сообщение
Проверяй результат на DBNull.Value, ибо его к int явно не привести (в общем случае)
Ммм...а в какой ситуации count может вернуть null?
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
23.09.2013, 15:34
Цитата Сообщение от greg_bond Посмотреть сообщение
Sql запрос следующий: @"SELECT name FROM sqlite_master WHERE type = 'table' AND tbl_name = 'orders_log'"
Вот в таком

Не по теме:


отвлекли просто, запостил уже появления поправки count

0
 Аватар для m0nax
1274 / 975 / 113
Регистрация: 12.01.2010
Сообщений: 1,971
23.09.2013, 22:19

Не по теме:

если че, я сказал как исправить описанную автором ошибку, а вы тут выясняйте дальше дбнуль там и всё такое



Добавлено через 11 минут
для надежности еще раз на пальцах
C#
1
n = (int)(Int64)sqlCommand.ExecuteScalar();
0
0 / 0 / 0
Регистрация: 20.06.2013
Сообщений: 15
24.09.2013, 14:23  [ТС]
Ребята всем спасибо!
Получить решение удалось использованием следующего метода:
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
public int CountExecuteScalar(string FileData, string sSql)
{
    object obj = null;
    int n = 0;
    try
    {
        using (SQLiteConnection con = new SQLiteConnection())   //Создание экземпляра класса SQLiteConnection
        {
            con.ConnectionString = @"Data Source=" + FileData + ";New=False;Version=3"; //строка соединения c БД
            con.Open();     //соединение
            using (SQLiteCommand sqlCommand = con.CreateCommand())
            {
                sqlCommand.CommandText = sSql;
                obj = sqlCommand.ExecuteScalar(); //метод из System.Data.SQLite.dll 
                n = (int)Convert.ChangeType(obj, typeof(int));//метод из System.Convert
            }
            con.Close();
        }
    }
    catch (Exception ex)
    {
        n = 0;
    }
    return n;
}
Sql команда следующая:
sSql ="SELECT COUNT(name) FROM sqlite_master WHERE TYPE = 'table' AND tbl_name = 'orders_log'"
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
24.09.2013, 15:05
Цитата Сообщение от greg_bond Посмотреть сообщение
(int)Convert.ChangeType(obj, typeof(int))
Вот зарадидля это? int к int привести?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.09.2013, 15:05
Помогаю со студенческими работами здесь

Ошибка Sql запроса, Необработанное исключение типа "System.Data.OleDb.OleDbException" в System.Data.dll
Необработанное исключение типа "System.Data.OleDb.OleDbException" в System.Data.dll Дополнительные сведения: Ошибка синтаксиса...

Авторизация в приложении и исключение типа "System.Data.SQLClient.SQLException" в System.Data.dll
Доброго времени суток, пробую сделать авторизацию в приложении по примеру. В итоге получил что данные из текстбоксов, наверное,...

Ошибка: An unhandled exception of type 'System.Data.OracleClient.OracleException' occurred in system.data.oracleclient.dll
а вы что хотите получить, уважаемый? кол-во выбранных записей, или какое-то конкретное значение?

Необработанное исключение типа "System.Data.SqlClient.SqlException" в System.Data.dll
Здраствуйте,помогите пожалуйста бедной девушке( При компилировании выдает ошибку : Необработанное исключение типа...

Необработанное исключение типа "System.Data.OleDb.OleDbException" в System.Data.dll
в чём ошибка private: System::Void button1_Click(System::Object^ sender, System::EventArgs^ e) { char text1; int text2; ...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
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, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru