Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Apakah mungkin untuk memasukkan data ke dalam tampilan MySQL?

Jika Anda menggunakan gabungan dalam, dan tampilan Anda berisi semua kolom di tabel dasar, maka tampilan Anda mungkin dapat diperbarui. Namun, untuk tampilan multi-tabel yang dapat diperbarui, INSERT dapat bekerja jika dimasukkan ke dalam satu tabel. Anda dapat membagi operasi penyisipan menjadi beberapa INSERT pernyataan.

Anda mungkin ingin membaca artikel berikut untuk informasi lebih lanjut tentang topik ini:

Perhatikan contoh berikut:

CREATE TABLE table_a (id int, value int);
CREATE TABLE table_b (id int, ta_id int, value int);

INSERT INTO table_a VALUES (1, 10);
INSERT INTO table_a VALUES (2, 20);
INSERT INTO table_a VALUES (3, 30);

INSERT INTO table_b VALUES (1, 1, 100);
INSERT INTO table_b VALUES (2, 1, 200);
INSERT INTO table_b VALUES (3, 2, 300);
INSERT INTO table_b VALUES (4, 2, 400);

Sekarang mari kita buat tampilan:

CREATE VIEW v AS 
    SELECT      a.id a_id, b.id b_id, b.ta_id, a.value v1, b.value v2
    FROM        table_a a
    INNER JOIN  table_b b ON (b.ta_id = a.id);

SELECT * FROM v;
+------+------+-------+------+------+
| a_id | b_id | ta_id | v1   | v2   |
+------+------+-------+------+------+
|    1 |    1 |     1 |   10 |  100 |
|    1 |    2 |     1 |   10 |  200 |
|    2 |    3 |     2 |   20 |  300 |
|    2 |    4 |     2 |   20 |  400 |
+------+------+-------+------+------+
4 rows in set (0.00 sec)

Berikut INSERT gagal:

INSERT INTO v (a_id, b_id, ta_id, v1, v2) VALUES (3, 5, 3, 30, 500);
-- ERROR 1393 (HY000): Can not modify more than one base table through a join view 

Tapi kita bisa membaginya menjadi dua operasi:

INSERT INTO v (a_id, v1) VALUES (3, 30);
-- Query OK, 1 row affected (0.00 sec)
INSERT INTO v (b_id, ta_id, v2) VALUES (5, 3, 500);
-- Query OK, 1 row affected (0.00 sec)

Hasil:

SELECT * FROM v;
+------+------+-------+------+------+
| a_id | b_id | ta_id | v1   | v2   |
+------+------+-------+------+------+
|    1 |    1 |     1 |   10 |  100 |
|    1 |    2 |     1 |   10 |  200 |
|    2 |    3 |     2 |   20 |  300 |
|    2 |    4 |     2 |   20 |  400 |
|    3 |    5 |     3 |   30 |  500 |
+------+------+-------+------+------+
6 rows in set (0.00 sec)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Batasan kunci asing MySQL 5.5 gagal ketika kunci asing ada

  2. SQL Query Gabung di CodeIgniter

  3. Apa cara terbaik untuk memigrasikan Django DB dari SQLite ke MySQL?

  4. Fungsi rekursif PHP untuk menghapus semua node anak menyebabkan stackoverflow

  5. Sequelize bulkCreate() mengembalikan nilai NULL untuk kunci utama