Конференция "Базы" » запрос не получается [D7, Access]
 
  • Tanya (09.05.14 03:53) [0]
  • Tanya (09.05.14 05:06) [1]
    а ну  DBGrid
  • turbouser © (09.05.14 05:09) [2]
    WHERE x=:xv AND x=:xv+n
    тут ошибка.
    если n - это должен быть параметр, тогда
    WHERE x=:xv AND x=:xv+:n
    но!
    такой запрос при n<>0 не вернет ничего
  • turbouser © (09.05.14 05:18) [3]
    вместо AND должен быть OR, если уж
    > в итоге я должна получить значения -два столбца x, Lx и
    > две строки значения
  • Tanya (09.05.14 05:24) [4]
    Спасибо вам   сейчас попробую
  • Tanya (09.05.14 05:31) [5]
    Все равно не находит параметр n ((
  • Tanya (09.05.14 05:45) [6]

    > но!такой запрос при n<>0 не вернет ничего

    то есть n больше, меньше 0? не поняла эту запись
  • Tanya (09.05.14 05:50) [7]
    а знак равносильности.   Исправила не получается.Может у меня все дело в параметрах ?
  • Tanya (09.05.14 06:57) [8]
    Если убрать второй параметр вообще, то с легкостью работает :(
  • sms (09.05.14 11:01) [9]
    что такое n?
  • Inovet © (09.05.14 12:43) [10]
    > [0] Tanya   (09.05.14 03:53)
    > xv, n -это параметры. То есть в итоге я должна получить
    > значения -два столбца x, Lx и две строки значения.

    Точно? Не диапазон (x-n, x+n)?
  • turbouser © (09.05.14 13:33) [11]
    Долго можно гадать :)

    > Tanya

    Текст ошибки сюда скопируй
  • Tanya (09.05.14 18:41) [12]
    только зашла
    Поясняю значит, я хочу чтобы в результате моего запроса отображалась два поля x и Lx, в первой строке отображалось значение  поля Lх по х столбцу, с введенным параметром  x=:xv, а во второй строке значение  поля Lх по х с веденным параметром x=:xv+:n, где xv и n параметрические переменные введенные в edit-ах. Например отображается x и Lx при х=40 и х=40+10 то есть 50.
    Текст ошибки: Project1.exe raised exception class EDatabase Error with message 'ADOQuery1: Parameter 'n' not found. Process stoped.
  • turbouser © (09.05.14 20:27) [13]

    > Tanya   (09.05.14 18:41) [12]


    >  'ADOQuery1: Parameter 'n' not found. Process stoped.

    Зайди еще раз в список параметров ADOQuery1. Бывает что после изминения запроса не схватывает.
  • Дмитрий (12.05.14 16:08) [14]

    > SELECT x, Lx FROM Таблица WHERE x=:xv AND x=:xv+nxv, n -
    > это параметры. То есть в итоге я должна получить значения
    > -два столбца x, Lx и две строки значения.В коде на кнопку
    > прописала ADOQuery1.Close;ADOQuery1.Parameters.ParamByName('xv').
    > Value:=Edit1.text;ADOQuery1.Parameters.ParamByName('n').
    > Value:=Edit2.text;

    У вас в запросе параметр ":xv" используется дважды.
    Параметр "n" - ни разу, т.к. не обозначен двоеточием.
    Поэтому, при подстановке,  "n" не будет найден вообще,
    ":xv" будет присвоен только один раз, поскольку будет воспринят парсером как два параметра с одинаковым именем.
    Для него либо используйте два разных имени передавая одну величину, либо ищите в цикле все параметры с названием "xv".
  • Дмитрий (12.05.14 16:16) [15]
    SELECT x, Lx
    FROM Таблица
    WHERE x=:xv1 or x=:xv2 + :n
    ADOQuery1.Parameters.ParamByName('xv1').Value:= Edit1.text;
    ADOQuery1.Parameters.ParamByName('xv2').Value:= Edit1.text;
    ADOQuery1.Parameters.ParamByName('n').Value:= Edit2.text;

    Однако, подставлять напрямую текст из боксов чревато запустить юзерскую ошибку, либо sql-инъекцию от злоумышленника.
    Хотя бы проводите преобразование к нужному типу данных во избежание.
  • sniknik © (12.05.14 16:47) [16]
    > либо sql-инъекцию от злоумышленника.
    sql-инъекция через параметры запроса не возможна. только при сборке запроса из частей.
  • Ega23 © (13.05.14 10:10) [17]

    > Однако, подставлять напрямую текст из боксов чревато запустить
    > юзерскую ошибку, либо sql-инъекцию от злоумышленника.


    Не болтайте ерундой.
  • Дмитрий (13.05.14 16:18) [18]
    Вы хотите сказать, что и пользовательская ошибка не возможна?
  • Inovet © (13.05.14 16:37) [19]
    > [18] Дмитрий   (13.05.14 16:18)

    Какая именно?
 
Конференция "Базы" » запрос не получается [D7, Access]
Есть новые Нет новых   [118607   +37][b:0][p:0]