Форум программистов, компьютерный форум, киберфорум
C++ Qt
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
 Аватар для tasty_sock
139 / 137 / 21
Регистрация: 26.01.2010
Сообщений: 350

Запрос возвращает меньше строк, чем должен

14.03.2012, 16:07. Показов 1315. Ответов 2

Студворк — интернет-сервис помощи студентам
Привет.

Есть interbase'овая база, коннекчусь к ней через QIBASE. Кодировка базы - 1251.

C++
1
2
3
4
5
6
7
8
    QSqlDatabase db = QSqlDatabase::addDatabase("QIBASE");
 
    db.setHostName("localhost");
    db.setDatabaseName(dbName);
    db.setUserName("sysdba");
    db.setPassword("masterkey");
 
    db.setConnectOptions("CHARSET=WIN1251");
Написал простенький селект:
C++
1
2
3
4
5
6
7
8
9
10
    QSqlQuery query("select kod_icao from aerodrom order by kod_icao asc", db);
    query.exec();
 
    int count = 0;
    while (query.next())
    {
        count++;
    }
 
    qDebug() << count;
Однако count в итоге получается меньше, чем
SQL
1
SELECT COUNT(*) FROM aerodrom
Выяснил, что Qt не воспринимает записи с кириллицей - не просто кракозябру возвращает, а вообще эти записи не видит. Что делать в таком случае?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.03.2012, 16:07
Ответы с готовыми решениями:

Запрос возвращает -1, а должен вернуть число строк в таблице
По задумке, эта конструкция должна вернуть количество строк в определенной таблице БД (MS SQL Server), но выводит, почему-то значение,...

Запрос, который должен посчитать количество записей в БД возвращает bool(false)
Доброго времени суток. Почему запрос, который должен посчитать количество записей в БД возвращает мне bool(false). Вот собственно сам...

Ascii код символа при дешифровании на еденицу меньше чем должен быть
Добрый вечер. Написал простенькую программку шифра Цезаря, но столкнулся с небольшой проблемой. Если десятичны код шифруемого символа...

2
109 / 36 / 3
Регистрация: 08.08.2009
Сообщений: 134
14.03.2012, 21:31
Тут возникает два вопроса.
1) А если в программе подставить запрос "SELECT * FROM aerodrom", то тоже получится больше чем count
2) Чтобы он воспринимал кирилицу попробуй установить кодеки
C++
1
2
3
4
    QTextCodec* codec = QTextCodec::codecForName("Windows-1251");
    QTextCodec::setCodecForCStrings(codec);
    QTextCodec::setCodecForLocale(codec);
    QTextCodec::setCodecForTr(codec);
1
 Аватар для tasty_sock
139 / 137 / 21
Регистрация: 26.01.2010
Сообщений: 350
14.03.2012, 21:45  [ТС]
Спасибо за участие.

Проблема была в другом. Я зафейлил, сказав, что база в 1251. Дефолтная кодировка на деле не была проставлена. С 1251 заработало на ура.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.03.2012, 21:45
Помогаю со студенческими работами здесь

Ошибка "startIndex должен быть меньше, чем длина строки."
Привет всем! Появилось вот эта вот ошибка, не могу её устранить &quot; Ошибка &quot;startIndex должен быть меньше, чем длина строки&quot; Вот...

Ошибка "startIndex должен быть меньше, чем длина строки."
Доброго времени суток! Задача такая: &quot;Достать из файла координаты x,y и z, преобразовать в некую строку, которую отправить...

Запрос возвращает ноль найденных строк
if ($stmt = $mysqli-&gt;prepare(&quot;SELECT `id`, `title` FROM `blog` WHERE `id_article` = '&quot;.$str.&quot;'&quot;)) { $stmt-&gt;execute(); ...

Строк меньше, чем вводимых данных
Есть 3 таблицы 1. Ученики (id_ученика, FIO_ученика, номер_телефона). 2. Родители (id_родителя, id_ученика1, FIO_мамы, FIO_папы,...

Запрос к mysql , возвращает в два раза больше строк
всем доброго дня, ситуация следующая: имею: таблицу из 2 строк и 4 столбцов (id, name, type, age), при запросе данной таблицы в ответе...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Камера 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, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru