Форум программистов, компьютерный форум, киберфорум
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. Показов 3740. Ответов 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
654 / 591 / 171
Регистрация: 17.07.2012
Сообщений: 1,680
Записей в блоге: 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
654 / 591 / 171
Регистрация: 17.07.2012
Сообщений: 1,680
Записей в блоге: 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
654 / 591 / 171
Регистрация: 17.07.2012
Сообщений: 1,680
Записей в блоге: 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
654 / 591 / 171
Регистрация: 17.07.2012
Сообщений: 1,680
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru