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

SQL Wstaw do tabeli nowe wiersze dla każdego pola w tej samej tabeli

W przypadku MySQL 8.0 lub nowszego możesz użyć następnego zapytania:

INSERT IGNORE INTO products
SELECT 
    id_product,
    143 as id_category,
    (
       SELECT MAX(position) 
       FROM products
       WHERE id_category = 143
     ) + 
     (row_number() over (order by id_product)) as position
FROM products
WHERE id_category = 12;

Wynik z SQLize.online :

+============+=============+==========+
| id_product | id_category | position |
+============+=============+==========+
| 190        | 12          | 10       |
+------------+-------------+----------+
| 191        | 12          | 11       |
+------------+-------------+----------+
| 230        | 12          | 12       |
+------------+-------------+----------+
| 15         | 143         | 12       |
+------------+-------------+----------+
| 150        | 143         | 50       |
+------------+-------------+----------+
| 190        | 143         | 51       |
+------------+-------------+----------+
| 191        | 143         | 52       |
+------------+-------------+----------+
| 230        | 143         | 53       |
+------------+-------------+----------+



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. mysql_upgrade nie powiodło się - tabele innodb nie istnieją?

  2. MySQL - Jak przeanalizować wartość ciągu do formatu DATETIME wewnątrz instrukcji INSERT?

  3. Konwertuj wszystkie kolumny w wierszach z daty na znacznik czasu MySQL

  4. tworzyć jcomponents za pomocą bazy danych

  5. MySqlParameter jako TableName