MySQL에서 뷰는 가상 테이블이고 실제 데이터는 기본 테이블에서 오기 때문에 삽입, 수정, 삭제 작업을 통해 뷰의 데이터 정보를 업데이트하는 것은 본질적으로 뷰에서 참조하는 기본 테이블의 데이터 정보를 업데이트하는 것입니다. 구문 형식은 "ALTER VIEW <뷰 이름> AS
구문 설명은 다음과 같습니다. <뷰 이름>: 뷰의 이름을 지정합니다. 이름은 데이터베이스에서 고유해야 하며 다른 테이블이나 뷰와 동일한 이름을 가질 수 없습니다.
: 여러 기본 테이블이나 소스 뷰를 쿼리하는 데 사용할 수 있는 뷰를 생성하려면 SELECT 문을 지정합니다.
ALTER VIEW 문을 사용하려면 사용자에게 뷰에 대한 CREATE VIEW 및 DROP 권한과 SELECT 문에서 선택한 각 열에 대한 특정 권한이 필요하다는 점에 유의해야 합니다.
ALTER VIEW를 통해 뷰 정의를 수정하는 것 외에도 DROP VIEW 문을 사용하여 먼저 뷰를 삭제한 다음 CREATE VIEW 문을 사용할 수도 있습니다. 일부 보기는 업데이트 가능합니다. 즉, UPDATE, DELETE 또는 INSERT와 같은 문을 사용하여 기본 테이블의 내용을 업데이트할 수 있습니다. 업데이트 가능한 뷰의 경우 뷰의 행과 기본 테이블의 행 사이에 일대일 관계가 있어야 합니다. 뷰를 업데이트할 수 없게 만드는 특정한 다른 구조도 있습니다. 보다 구체적으로,
집계 함수 SUM(), MIN(), MAX(), COUNT() 등의 구조가 포함된 경우 뷰를 업데이트할 수 없습니다.
DISTINCT 키워드.
GROUP BY 절. HAVING 조항. UNION 또는 UNION ALL 연산자.
선택 목록에 위치한 하위 쿼리입니다.
FROM 절에 있거나 여러 테이블이 포함된 업데이트할 수 없는 뷰입니다.
FROM 절의 테이블을 참조하는 WHERE 절의 하위 쿼리입니다.
ALGORITHM 옵션은 TEMPTABLE입니다(임시 테이블을 사용하면 항상 뷰를 업데이트할 수 없게 됩니다).
【예제 1】ALTER 문을 사용하여 view_students_info 뷰를 수정합니다. 입력 SQL 문과 실행 결과는 다음과 같습니다.
mysql> ALTER VIEW view_students_info
-> AS SELECT id,name,age
-> FROM tb_students_info;
Query OK, 0 rows affected (0.07 sec)
mysql> DESC view_students_info;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id | int(11) | NO | | 0 | |
| name | varchar(45) | YES | | NULL | |
| age | int(11) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.03 sec)
로그인 후 복사
뷰는 데이터가 없는 가상 테이블이기 때문에 사용자는 뷰를 통해 테이블에 데이터를 삽입, 업데이트, 삭제할 수 있습니다. 뷰를 통해 업데이트할 경우 기본 테이블로 이동하여 업데이트됩니다. 뷰에 레코드가 추가되거나 삭제되면 실제로는 기본 테이블에 레코드가 추가되거나 삭제됩니다. 아래와 같이 view_students_info 보기의 데이터 내용을 봅니다.
mysql> SELECT * FROM view_students_info;
+----+--------+------+
| id | name | age |
+----+--------+------+
| 1 | Dany | 24 |
| 2 | Green | 23 |
| 3 | Henry | 23 |
| 4 | Jane | 22 |
| 5 | Jim | 24 |
| 6 | John | 21 |
| 7 | Lily | 22 |
| 8 | Susan | 23 |
| 9 | Thomas | 22 |
| 10 | Tom | 23 |
+----+--------+------+
10 rows in set (0.00 sec)
로그인 후 복사
[예제 2] UPDATE 문을 사용하여 view_students_info 뷰를 업데이트합니다. 입력 SQL 문과 실행 결과는 다음과 같습니다.
mysql> UPDATE view_students_info
-> SET age=25 WHERE id=1;
Query OK, 0 rows affected (0.24 sec)
Rows matched: 1 Changed: 0 Warnings: 0
mysql> SELECT * FROM view_students_info;
+----+--------+------+
| id | name | age |
+----+--------+------+
| 1 | Dany | 25 |
| 2 | Green | 23 |
| 3 | Henry | 23 |
| 4 | Jane | 22 |
| 5 | Jim | 24 |
| 6 | John | 21 |
| 7 | Lily | 22 |
| 8 | Susan | 23 |
| 9 | Thomas | 22 |
| 10 | Tom | 23 |
+----+--------+------+
10 rows in set (0.00 sec)
로그인 후 복사
아래와 같이 기본 테이블 tb_students_info의 내용과 v_students_info를 확인합니다. 아아아아
위 내용은 mysql 뷰에서 테이블의 정보를 수정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!