Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Выборка из БД через переменные.MSVC++6, ADO, MSSQL  (Прочитано 7294 раз)
0 Пользователей и 1 Гость смотрят эту тему.
nicvc
Гость
« : 06-03-2007 21:44 » 

Не могу сделать выборку из БД для отображения в Гриде.
Пробовал так:
int Node = 5;
    //char* Node = 'Автор'
sql.Format("SELECT ParamName, ParamNode FROM TabGrid WHERE ParamNode = Node ");

Не получается подставить переменную.

Только начал вникать в SQL.
Подскажите как делаются выборки строк через переменные.
Записан
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #1 : 07-03-2007 06:27 » 

nicvc, переменные запроса и переменные твоей программы никак не пересекаются. Это в корне разные вещи.

Честно говоря, с M$SQL не работал, но полагаю, там принцип такой же, как и в других БД.
В Oracle делают так: объявляют имя и тип переменной (соотв. ф-ией), а в запросе подставляют ":VARNAME".
Видел интерфейсы, в которых подстановки делаются знаками вопроса.

Тебе нужно заглянуть в доку! msdn.com поможет.

Цитата
Подскажите как делаются выборки строк через переменные.
Поясни, что ты имеешь в виду?
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
HandKot
Молодой специалист

ru
Offline Offline

« Ответ #2 : 07-03-2007 06:33 » 

в С++ не силен, но примерно так
Код:
sql.Format("SELECT ParamName, ParamNode FROM TabGrid WHERE ParamNode = " & Node  & ")";

но лучше использовать параметрированные запросы
Записан

I Have Nine Lives You Have One Only
THINK!
nicvc
Гость
« Ответ #3 : 07-03-2007 14:02 » 

Ответ уже нашел:
int Node = 5;
sql.Format("SELECT ParamName, ParamNode, NodeName FROM TabGrid WHERE ParamNode = %d", Node);
const char* Node = "' Автор '"; или char* Node = "'Автор'";
sql.Format("SELECT ParamName, ParamNode, NodeName FROM TabGrid WHERE NodeName = %s", Node);
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines