Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.12.03;
Скачать: CL | DM;

Вниз

Запрос   Найти похожие ветки 

 
NigthSkif   (2006-11-13 06:52) [0]

Доброе время суток всем. Скажите, что не так

q := TQuery.Create(nil);
  q.DatabaseName := "DB";
  q.Close;
  q.Params.CreateParam(ftInteger, "Rez", ptOutput);
  q.Params.CreateParam(ftString, "NewName", ptInput);
  q.SQL.Clear;
  q.Params.ParamByName("NewName").AsString := edtName.Text;
  q.SQL.Add("IF EXISTS (SELECT Nam FROM dbNames WHERE Nam= :NewName) " +
              "SELECT begin :Rez=1 end "+
            "ELSE " +
              "begin " +
                  "INSERT INTO dbNames(Nam) " +
                  "VALUES(NewName) " +
                  "SELECT :Rez=0 " +
              "end");

  q.ExecSQL;
  i := q.Params.ParamByName("Rez").AsInteger;
  q.Close;
  q.Destroy;

Когда выполнятся, говорит следующее: Field Rez=1 is of an unknown type.
Чем лечить?


 
Johnmen ©   (2006-11-13 10:04) [1]


>  Скажите, что не так


1. q.Close;
Зачем закрывать неоткрытую дверь?
2. q.SQL.Clear;
Зачем выливать воду из пустого стакана?
3. Такое создание параметров - это бред. Как работать с параметрическим запросом написано в F1 с примерами.
4. И самое главное
IF EXISTS ....
Это не запрос!


 
Anatoly Podgoretsky ©   (2006-11-13 10:21) [2]

3. и бессмысленно, они все равно уничтожаются несколькими строками ниже и не один раз


 
Desdechado ©   (2006-11-13 11:47) [3]

Anatoly Podgoretsky ©   (13.11.06 10:21) [2]
Это зависит от настроек TQuery, но поскольку автор их не меняет, то действительно у него все параметры затираются.

5. Обращение Params.ParamByName несколько избыточно, достаточно просто ParamByName



Страницы: 1 вся ветка

Текущий архив: 2006.12.03;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.034 c
2-1163229279
#0FFFF
2006-11-11 10:14
2006.12.03
Иконка компонента


2-1163532643
DoktorX
2006-11-14 22:30
2006.12.03
как из ImageList отобразить рисунок под номером 2


2-1163158594
Kolan
2006-11-10 14:36
2006.12.03
Как заставить DBGrid выравнивать ячейки по тексту.


2-1163778805
Adios
2006-11-17 18:53
2006.12.03
?


1-1161604870
Германн
2006-10-23 16:01
2006.12.03
Размер множества