반응형
MySQL 뷰에 데이터를 삽입할 수 있습니까?
테이블 4개로 MySQL 뷰를 만들었습니다.뷰에 데이터를 삽입하여 MySQL에서 자동으로 오른쪽 테이블로 데이터를 전달할 수 있습니까?
내부 조인을 사용하는 경우 뷰에 기본 테이블의 모든 열이 포함된 경우 뷰를 업데이트할 수 있습니다.그러나 다중 테이블 업데이트 가능 뷰의 경우,INSERT
는, 1개의 테이블에 삽입하면 동작합니다.삽입 작업을 여러 개로 분할할 수 있습니다.INSERT
진술들.
이 토픽의 상세한 것에 대하여는, 다음의 기사를 참조해 주세요.
다음 예를 생각해 보겠습니다.
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);
이제 보기를 만듭니다.
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)
이하와 같다INSERT
실패:
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
그러나 두 가지 작업으로 나눌 수 있습니다.
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)
결과:
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)
언급URL : https://stackoverflow.com/questions/3825941/is-it-possible-to-insert-data-into-a-mysql-view
반응형
'IT' 카테고리의 다른 글
MySQL의 utf8mb4와 utf8 문자 집합의 차이점은 무엇입니까? (0) | 2022.10.29 |
---|---|
Java의 마커 인터페이스? (0) | 2022.10.29 |
여러 개의 컬럼과 제한 2로 그룹화하시겠습니까? (0) | 2022.10.28 |
JPA getSingleResult() 또는 늘 (0) | 2022.10.28 |
pylab과 pyplot의 차이점은 무엇입니까? (0) | 2022.10.28 |