Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
 Аватар для SenkoL
1 / 1 / 1
Регистрация: 04.05.2013
Сообщений: 47

Ошибка сравнения символов в строках в БД

16.04.2014, 12:55. Показов 692. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте уважаемые форумчане!

Среда Borland C++ XE
Пытаюсь в приложении базы данных сравнить символы в строках, если равны, то ADOQuery пишем один запрос, если нет, то пишем другой запрос.
Проблема возникает в вроде бы элементарных вещах - сравнении символов.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
//получаем в переменную значение поля текущей строки
String num_uch = ADOQuery1->FieldByName("ID_num_uch")->AsString;
 
bool valid = false; //переменная для проверки наличия символа
 
//проверяем есть ли в данной строке русский символ "Т"
for(int i=0; i< StrToInt(num_uch.Length()); i++){
     if (strcmp(num_uch[i],"Т")) valid=true;
}
if(valid){
             query1 = "SELECT * FROM tab1";
}else{
             query1 = "SELECT * FROM tab2";
}
В результате вылетает ошибка на строке (if (strcmp(num_uch[i],"Т"))) --- E2034: Cannot convert 'int' to 'const char *'

Добавлено через 14 минут
пофиксил так:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
//Добавил след.:
AnsiString u = num_uch;
char *u2 = u.c_str();
 
bool valid = false;
 
//цикл изменил на:
 
for(int i=0; i< StrToInt(num_uch.Length()); i++){
    if (u2[i]=='Т'){
        valid=true;
    }
}
все прекрасно работает, но все таки, может кто знает решение данного вопроса без подобных костылей ?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.04.2014, 12:55
Ответы с готовыми решениями:

Сравнения слов в двух строках
Дано две строчные переменные, которые содержат по несколько слов, разделенных пробелами. Воспользовавшись указателями, определить, есть ли...

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

С помощью подпрограммы определить количество символов ‘п' и ‘у’ в строках из 100 и 300 символов.
Ребят,вот эту задачу помогите ещё сделать пожалуйста С помощью подпрограммы определить количество символов ‘п' и ‘у’ в ...

3
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
16.04.2014, 12:55
Цитата Сообщение от SenkoL Посмотреть сообщение
strcmp
Насколько я знаю функция strcmp сравнивает только латынь, а кирилицу этой функцией сравнивать нельзя
1
 Аватар для Within_t
34 / 21 / 11
Регистрация: 20.10.2013
Сообщений: 577
06.05.2014, 20:41
Цитата Сообщение от Sasha Посмотреть сообщение
strcmp
для сравнения, если мне не изменяет память подойдет Функция CompareText
0
Модератор
 Аватар для D1973
9929 / 6467 / 2457
Регистрация: 21.01.2014
Сообщений: 27,423
Записей в блоге: 3
08.05.2014, 11:38
C++
1
2
3
4
//получаем в переменную значение поля текущей строки
String num_uch = ADOQuery1->FieldByName("ID_num_uch")->AsString;
if(num_uch.Pos("Т")) query1 = "SELECT * FROM tab1";
else query1 = "SELECT * FROM tab2";
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.05.2014, 11:38
Помогаю со студенческими работами здесь

Вывод символов, расположенных после определённых символов в определённых строках заданного файла
Есть файл &quot;work/Разобранные/%capp%/apktool.yml&quot; (Значение %capp% задаётся свыше...) Такого типа: version: 2.0.0-Beta9 apkFileName:...

Написать программу для сравнения двух строк символов
Результат должен быть &quot;больше&quot;,&quot;меньше&quot;,&quot;равно&quot;(сравнение лексикографическое - сначала по первой букве, в случае совпадения - по второй и...

Фильтр символов в строках
Здравствуйте! Имеется ввод с консоли, есть некоторое условие, а именно - вводимые строки должны состоять из последовательности латинских...

Сравнение символов в строках
Здравствуйте. Будьте добры, объясните начинающему. Есть две строки a и а1, нужно узнать есть ли в строке а1 хоть один символ который есть в...

Сравнение символов в строках
Добрый день! помогите написать прогу, которая будет сравнивать две строки и показывать каких символов нет в 1-ой строке из 2-ой строки.


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru