>데이터 베이스 >MySQL 튜토리얼 >SQL 보기 세부정보

SQL 보기 세부정보

黄舟
黄舟원래의
2017-02-27 13:34:422576검색

보기

보기는 가상 테이블입니다. 포함된 데이터 테이블과 달리 뷰에는 쿼리에서 사용될 때 동적으로 검색되는 데이터만 포함됩니다. 뷰에는 열이나 데이터가 포함되지 않고 쿼리만 포함됩니다.

뷰를 사용하는 이유는 무엇인가요?

1: SQL 문을 재사용합니다.

2: 복잡한 SQL 작업을 단순화합니다. 쿼리를 작성한 후에는 기본 쿼리의 세부정보를 몰라도 쉽게 재사용할 수 있습니다.

3: 테이블 전체 대신 테이블의 일부를 사용하세요.

4: 데이터를 보호합니다. 사용자는 전체 테이블이 아닌 테이블의 특정 부분에 대한 액세스 권한을 부여받을 수 있습니다.

5: 데이터 형식 및 표현을 변경합니다. 뷰는 기본 테이블과 다르게 표시되고 형식이 지정된 데이터를 반환할 수 있습니다.

뷰를 생성한 후에는 테이블과 거의 동일한 방식으로 사용할 수 있습니다. 뷰에 대해 SELECT 작업을 수행하고, 데이터를 필터링 및 정렬하고, 뷰를 다른 뷰나 테이블에 조인할 수 있습니다.

뷰는 단순히 다른 곳에 저장된 데이터를 보기 위한 설정이라는 점을 아는 것이 중요합니다. 뷰 자체에는 데이터가 포함되어 있지 않으므로 반환된 데이터는 다른 테이블에서 검색됩니다. 이러한 테이블에 데이터를 추가하고 변경하면 뷰는 변경된 데이터를 반환합니다.

뷰 생성 및 사용과 관련된 가장 일반적인 규칙 및 제한 사항

(1) 테이블과 마찬가지로 뷰의 이름은 고유해야 합니다

(2) 웨어러블의 경우 조회수에는 제한이 없습니다

(3) 뷰를 생성하기 위해서는 충분한 접근권한이 있어야 합니다. 이러한 권한은 일반적으로 데이터베이스 관리자가 부여합니다.

(4) 뷰는 중첩될 수 있습니다. 즉, 다른 뷰에서 데이터를 검색하는 쿼리를 사용하여 뷰를 구성할 수 있습니다.

(5) 많은 DBMS에서는 뷰 쿼리에 ORDER BY 절 사용을 금지하고 있습니다.

(6) 일부 DBMS에서는 반환되는 모든 열의 이름을 지정해야 합니다. 열이 계산된 필드인 경우 별칭을 사용해야 합니다.

(7) 뷰는 색인화할 수 없으며 관련 트리거 또는 기본값을 가질 수 없습니다.

(8) 일부 DBMS는 뷰를 읽기 전용 쿼리로 사용합니다. 즉, 뷰에서 데이터를 검색할 수 있지만 기본 테이블에 데이터를 쓸 수는 없습니다.

(9) 일부 DBMS에서는 행이 더 이상 뷰에 속하지 않게 만드는 삽입이나 업데이트를 허용하지 않는 뷰 생성을 허용합니다.



뷰 생성

뷰는 CREATE VIEW 문을 사용하여 생성됩니다.

뷰를 삭제하려면 DROP 문을 사용하세요. 구문은 다음과 같습니다: DROP VIEW viewname;

뷰를 사용하여 복잡한 연결을 단순화

CREATE VIEW ProductCustomers ASSELECT cust_name,cust_contact,prod_idFROM Customers,Orders,
OrderItemsWHERE Customers.cust_id = Order.cust_id AND OrderItems.order_num = Order.order_num;

이 문 ProductCustomers라는 A 뷰를 생성하여 세 개의 테이블을 조인하여 제품을 주문한 모든 고객의 목록을 반환합니다.

RGAN01 상품을 주문한 고객 조회

SELECT cust_name,cust_contactFROM ProductCustomersWHERE prod_id = 'RGAN01';

用视图重新格式化检索出的数据

创建格式化视图

CREATE VIEW VendorsLocations ASSELECT RTRM(vend_name) || ' ( ' || RTRIM(vend_country) || ' ) ' AS vend_titleFROM Vendors;

用试图过滤不想要的数据

定义CustomerEMailList 视图,过滤没有电子邮件地址的客户。

CREATE VIEW CustomerEMailList ASSELECT cust_id, cust_name, cust_emailFROM CustomersWHERE cust_email IS NOT NULL;

使用视图与计算字段

检索某个特定订单中的物品,计算每种物品的总价格

CREATE VIEW OrderItemExpanded ASSELECT order_num, prod_id, quantity, item_price, quantity*item_price AS expanded_price
FROM OrderItems;

根据视图检索订单20008的详细内容

SELECT *FROM OrderItemsExpandedWHERE order_num = 20008;

 以上就是SQL视图 详细介绍的内容,更多相关内容请关注PHP中文网(www.php.cn)!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.