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

Вниз

Использование переменной внутри запроса.   Найти похожие ветки 

 
Leo ©   (2008-05-21 15:36) [0]

Есть таблица значений AutoInc для всех таблиц базы. База многопользовательская, поэтому для каждого клиента нужен уникальный ID. Соответственно запрос

lock tables `autoinc` write;
select `value` into @val from `autoinc` where `table` = "table2";
SET @val = @val + 1;
UPDATE `autoinc`
   SET `Value` = @val
   WHERE `table` = "table2"
   LIMIT 1;
unlock tables;
select @val;

Выдает ошибку "Can not open s Resultset".
Локализовал проблему:
1. select `value` into @val from `autoinc` where `table` = "table2";
2. select @val;
Та же ошибка, но когда выполняешь шаг 1, а затем шаг 2 по-отдельности, все ок.
MySql работает под WinXP. Пробовал под Линухом - все ок, работает.
Может кто-то сталкивался (думаю что-то в настройках).


 
Leo ©   (2008-05-23 17:45) [1]

Поставил вместо heidisql 3.0 -heidisql 3.2, заработало.


 
Ega23 ©   (2008-05-23 19:03) [2]

А нафига LIMIT?


 
Leo ©   (2008-05-24 14:00) [3]


> А нафига LIMIT?

Работает и без него, как вариант поле table проиндексить с unigue



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

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

Наверх




Память: 0.47 MB
Время: 0.018 c
3-1211865605
cad2206
2008-05-27 09:20
2008.12.21
Помогите построить запрос


15-1224052782
AlekseyB
2008-10-15 10:39
2008.12.21
Вирус autorun.inf


15-1224047537
kay
2008-10-15 09:12
2008.12.21
Выбор СУБД


2-1225564992
codemaster
2008-11-01 21:43
2008.12.21
Перенос Item в TListBox


1-1204794855
dmitry_12_08_74
2008-03-06 12:14
2008.12.21
Формирование ресурсов полупрозрачных куросров