sql >> Databáze >  >> RDS >> Mysql

Jak najít všechny podřízené řádky v MySQL?

Viz Rekurzivní dotaz MySQL s relační innoDB

Včera jsem poslal odpověď na totéž

Aktualizace:

Níže je function na základě výše uvedeného odkazu, ale byl přizpůsoben vašemu DELETE požadavky

CREATE PROCEDURE `delete_relations`(`_id` INT)
BEGIN
DECLARE  delete_row_ids varchar(200);
DECLARE id, id2 varchar(200);
DECLARE rows_affected int;

SET delete_row_ids  = _id;
SET id              = _id;
SET id2             = id;

WHILE id2 IS NOT NULL DO 
    SET id = NULL;
    SELECT GROUP_CONCAT( hierarchical_data.id ), CONCAT( GROUP_CONCAT( hierarchical_data.ID ),',',delete_row_ids) INTO id, delete_row_ids FROM hierarchical_data WHERE FIND_IN_SET( parentid , id2 ) GROUP BY parentid ;
    SET id2 = id;
END WHILE;  

DELETE FROM hierarchical_data where FIND_IN_SET(hierarchical_data.id, delete_row_ids);
SELECT row_count() INTO rows_affected;

if rows_affected > 0 THEN
SELECT delete_row_ids as row_ids_deleted;
ELSE
SELECT 'NO_ROWS_DELETED';
END IF;

END//

SQLFiddle

Použijte

CALL delete_relations(1)

Chcete-li odstranit všechny položky a jejich vztahy pro id = 1 honda

Doufám, že to pomůže



  1. Jaký je nejlepší způsob, jak zkrátit datum na serveru SQL Server?

  2. Jak odstranit jedinečný klíč z tabulky mysql

  3. Rozhodněte se mezi monitorováním na základě agenta a monitorováním bez agenta

  4. Problém účinnosti/struktury databáze