Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. Программирование. Ступени успешной карьеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Циклическая обработка данных
 
 автор: sl1p   (24.10.2008 в 10:58)   письмо автору
 
 

возможно ли както сделать цикл в запросе?
тоесть нужно чтото типа такого:

есть 2 таблицы:

берём оттуда всех у кого id меньше 100 удаляем и записываем эти удалённые айди тоесть каждую строку для каждого отдельного айди в другую таблицу?

  Ответить  
 
 автор: ronin80   (24.10.2008 в 18:00)   письмо автору
 
   для: sl1p   (24.10.2008 в 10:58)
 

я думаю тут больше подойдёт процедура

  Ответить  
 
 автор: Trianon   (24.10.2008 в 18:39)   письмо автору
 
   для: ronin80   (24.10.2008 в 18:00)
 

Какая процедура?
Задача решается двумя операторами.

  Ответить  
 
 автор: sl1p   (25.10.2008 в 02:03)   письмо автору
 
   для: Trianon   (24.10.2008 в 18:39)
 

тоесть только пхп?

  Ответить  
 
 автор: Trianon   (25.10.2008 в 10:31)   письмо автору
 
   для: sl1p   (25.10.2008 в 02:03)
 

Двумя операторами SQL - я имел в виду.

  Ответить  
 
 автор: sl1p   (25.10.2008 в 12:31)   письмо автору
 
   для: Trianon   (25.10.2008 в 10:31)
 

ну а написать не? :\

я как бы от того что они есть не щаслив:))

2ols это бред, мне с каждым айди нужно действия проводить. Я не совсем ещё туп:)

  Ответить  
 
 автор: Trianon   (25.10.2008 в 13:04)   письмо автору
 
   для: sl1p   (25.10.2008 в 12:31)
 

ну а в мануал заглянуть не? :\
INSERT INTO tbl ... SELECT ....

  Ответить  
 
 автор: ronin80   (25.10.2008 в 17:46)   письмо автору
 
   для: Trianon   (24.10.2008 в 18:39)
 

а я и не отрицаю что необходимо выполнение двух операторов, так как здесь требуется два действия: вставка записей и затем удаление их из таблицы источника

вопрос в том как это лучше реализовать, либо средствами php либо в виде хранимой процедуры

для меня удобней воспользоваться процедурой, обеспечив таким образом гарантирование целостности операции посредством использования транзакции и обработчиков исключительных ситуаций на случай ошибок выполнения sql операторов

если вы считаете что это глупо, чтож, тогда я умываю руки

  Ответить  
 
 автор: Trianon   (25.10.2008 в 18:04)   письмо автору
 
   для: ronin80   (25.10.2008 в 17:46)
 

Я ж спорю разве? Всё так.
Предложите автору хранимую процедуру - он щаслив станет.

  Ответить  
 
 автор: ronin80   (25.10.2008 в 18:20)   письмо автору
 
   для: Trianon   (25.10.2008 в 18:04)
 

DELIMITER //
DROP PROCEDURE IF EXISTS delete_and_insert//

CREATE PROCEDURE delete_and_insert ()
SQL SECURITY INVOKER
BEGIN

DECLARE EXIT HANDLER FOR SQLSTATE '23000', SQLEXCEPTION
BEGIN
ROLLBACK;
END;

START TRANSACTION;

/*вставляем записи во вторую таблицу*/
Insert Into table2 (id)
Select (id) From table1
Where id<100;

/*удаляем записи из первой таблицы*/
Delete from table1
Where id<100;

COMMIT;

END//
DELIMITER ;

не судите строго если что не так :)

  Ответить  
 
 автор: sl1p   (26.10.2008 в 02:54)   письмо автору
 
   для: ronin80   (25.10.2008 в 18:20)
 

омг, а как теперь с этим работать?)

мне например нужно забрать поле у каждого удаляемого и потом удалить его..
тоесть я как бы не совсем понял что это и как:)

  Ответить  
 
 автор: ols   (25.10.2008 в 10:57)   письмо автору
 
   для: sl1p   (24.10.2008 в 10:58)
 

1) Переноити в другую таблицу строки где id<100 (я вот не помню sql-оператор, который реализует это, но он есть (Trianon, подскажет :) )

2) DELETE FROM table WHERE id<100

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования