Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
unterminated dollar-quoted string
|
|||
|---|---|---|---|
|
#18+
create or replace function select_login_all (text, text) returns SETOF record as 'SELECT * FROM admin WHERE username=$1 AND password=$2 AND active=1' language sql; Запрос: SELECT * from select_login_all($fUsername1, $password) as (username varchar, password varchar, created timestamp, modified timestamp, active smallint) Два вопроса: 1 - при попытке селекта ошибка: Invalid query: ERROR: unterminated dollar-quoted string at or near "$f47c41cf$vuQp4qP8Hkhev3v3VFdwa1) as (username varchar, password varchar, created timestamp, modified timestamp, active smallint)" at character 50 В поле password - хеш пароля и там есть $. Как исправить? Нашел что-то про функции quote_literal - но ведь лишние слеши в этой строке мне тоже не нужны. 2 - Можно написать это же запрос как-то красивее? п.с. Делается так, чтоб выдать пользователю права только на функцию. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 10.03.2007, 13:06 |
|
||
|
unterminated dollar-quoted string
|
|||
|---|---|---|---|
|
#18+
neoweb Запрос: SELECT * from select_login_all($fUsername1, $password) as (username varchar, password varchar, created timestamp, modified timestamp, active smallint) Два вопроса: 1 - при попытке селекта ошибка: Invalid query: ERROR: unterminated dollar-quoted string at or near "$f47c41cf$vuQp4qP8Hkhev3v3VFdwa1) as (username varchar, password varchar, created timestamp, modified timestamp, active smallint)" at character 50 В поле password - хеш пароля и там есть $. Как исправить? Нашел что-то про функции quote_literal - но ведь лишние слеши в этой строке мне тоже не нужны. A v kavychki login i parol' ne probovali zakluchat' ? (esli vy uvereny, chto kavychek v username i parole net) SELECT * from select_login_all('$fUsername1', '$password') as (username varchar, password varchar, created timestamp, modified timestamp, active smallint); neoweb 2 - Можно написать это же запрос как-то красивее? Naprimer opredelit' functsiu tak: Код: plaintext 1. 2. 3. 4. i vyzyvat' ee tak: SELECT * from select_login_all('$fUsername1', '$password') ; ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.03.2007, 02:49 |
|
||
|
unterminated dollar-quoted string
|
|||
|---|---|---|---|
|
#18+
Спасибо. В этом разобрался. еще вопросик: Почему запросы не эквивалентны??? select * from table where username = quote_literal($1) select * from table where username = $1 т.е. первый запрос не возвращает ничего, а второй работает нормально. Пробовал не в контексте хп: select * from table where username = quote_literal('admin@domain.com') и select * from table where username = 'admin@domain.com' Результат такой же. Что же делать, если мне нужно использовать quote_literal? Спасибо. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.03.2007, 13:09 |
|
||
|
unterminated dollar-quoted string
|
|||
|---|---|---|---|
|
#18+
Код: plaintext 1. 2. 3. 4. quote_literal(string) Return the given string suitably quoted to be used as a string literal in an SQL statement string => Код: plaintext 1. 2. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.03.2007, 09:58 |
|
||
|
|

start [/forum/topic.php?fid=53&fpage=301&tid=2005618]: |
0ms |
get settings: |
9ms |
get forum list: |
19ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
40ms |
get topic data: |
13ms |
get forum data: |
4ms |
get page messages: |
55ms |
get tp. blocked users: |
2ms |
| others: | 228ms |
| total: | 378ms |

| 0 / 0 |
