Mysql
 sql >> Baza danych >  >> RDS >> Mysql

SQL :pętla przez tę samą tabelę

coś takiego? SKRZYPKI w celach informacyjnych

SELECT project_id,project_name,parent_id,recycle_bin,creater_id
FROM projectdetails AS pd1
JOIN(
    SELECT parent_id FROM projectdetails as pd
    WHERE pd.parent_id > 0 AND pd.recycle_bin > 1
) AS t ON t.parent_id = pd1.project_id

z nowymi danymi.. NEW_FIDDLE

SELECT 
  if(pd1.recycle_bin >1, pd1.project_id, t.project_id) AS project_id,
  if(pd1.recycle_bin >1, pd1.project_name, t.project_name) AS project_name,
  if(pd1.recycle_bin >1, pd1.parent_id, t.parent_id) AS parent_id,
  if(pd1.recycle_bin >1, pd1.recycle_bin, t.recycle_bin) AS recycle_bin,
  if(pd1.recycle_bin >1, pd1.creater_id, t.creater_id) AS creater_id
FROM projectdetails AS pd1
JOIN(
  SELECT * FROM projectdetails AS pd
  WHERE pd.parent_id > 0 
    AND pd.recycle_bin > 1
) AS t ON t.parent_id = pd1.project_id
GROUP BY project_id

bez użycia LAST_FIDDLE IF

SELECT 
   pd1.project_id,
   pd1.project_name,
   pd1.parent_id,
   pd1.recycle_bin,
   pd1.creater_id
FROM projectdetails AS pd1
WHERE NOT EXISTS(
  SELECT pd.recycle_bin FROM projectdetails as pd
  WHERE pd1.parent_id = pd.project_id 
    AND pd.recycle_bin > 1
) AND pd1.creater_id = 7923 and pd1.recycle_bin > 1
GROUP BY pd1.project_id;


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Utwórz nowego użytkownika w MySQL i daj mu pełny dostęp do jednej bazy danych

  2. Migracja online z MySQL 5.6 bez GTID do MySQL 5.7 z GTID

  3. Zbyt wiele automatycznych przyrostów przy ON DUPLICATE KEY UPDATE

  4. CodeIgniter update_batch bez zastępowania poprzednich danych następna zaktualizowana wartość zostanie umieszczona przecinkiem oddzielonym jako przyrost

  5. Operacja typu Pivot MySQL, aby uzyskać podział procentu wszystkich zdarzeń dziennie według typu zdarzenia