>데이터 베이스 >MySQL 튜토리얼 >데이터베이스 뷰와 테이블의 차이점은 무엇입니까

데이터베이스 뷰와 테이블의 차이점은 무엇입니까

青灯夜游
青灯夜游원래의
2021-05-07 14:07:5536668검색

차이점: 1. 뷰는 컴파일된 SQL 문이지만 테이블은 없습니다. 2. 뷰에는 실제 물리적 레코드가 없습니다. 3. 테이블은 내용이고 뷰는 창입니다. 5. 테이블은 개념적 스키마이고, 뷰는 외부 스키마입니다. 6. 테이블은 글로벌 스키마의 테이블에 속하고, 뷰는 로컬 스키마의 테이블에 속합니다.

데이터베이스 뷰와 테이블의 차이점은 무엇입니까

이 튜토리얼의 운영 환경: windows7 시스템, mysql8, Dell G3 컴퓨터.

데이터베이스의 뷰와 테이블의 차이점

  • 뷰는 컴파일된 SQL 문이지만 테이블은 그렇지 않습니다.

  • 뷰에는 실제 물리적 레코드가 없지만 테이블에는 내용이 있습니다. , 뷰는 창입니다.

  • 테이블은 물리적 공간을 차지하지만 뷰는 논리적 개념일 뿐이지만, 뷰는 시간에 따라 수정될 수 있습니다.

  • 테이블은 3단계 스키마 구조의 개념적 스키마이고, 뷰는 외부 스키마입니다.

  • 뷰는 데이터 테이블을 조회하는 방법입니다. 데이터 테이블의 특정 필드로 구성된 데이터 컬렉션은 보안 관점에서 사용자가 데이터 테이블에 액세스하는 것을 허용하지 않으므로

  • 테이블은 전역 스키마의 테이블에 속하며 실제 테이블인 반면, 뷰는 로컬 스키마의 테이블에 속하며 가상 테이블입니다.

  • 뷰 생성 및 삭제는 뷰 자체에만 영향을 미치며, 해당 기본 테이블은

  • 업데이트하거나 뷰에 삽입할 수 없습니다.

뷰와 데이터베이스 테이블의 연결

1. 뷰는 구조(즉, 정의된 열)와 내용(즉, 모든 데이터 행)을 기반으로 구축된 테이블입니다. 2. 뷰는 하나의 기본 테이블 또는 여러 기본 테이블에 해당할 수 있습니다. 3. 뷰는 논리적 의미의 관계에서 생성된 기본 테이블과 새로운 테이블의 추상화입니다.

요약:

뷰는 하위 쿼리이며 (SQL 내 최적화에도 불구하고) 직접 쿼리에 비해 성능이 확실히 낮으므로 뷰를 사용할 때 주의해야 할 한 가지는 중첩 쿼리, 특히 복잡한 쿼리를 사용하지 않는 것입니다. 쿼리.


뷰의 용도

1. 쿼리를 하위 쿼리로 자주 사용해야 하는 경우 뷰는 매번 이런 내용을 반복적으로 작성하는 대신 코드를 단순화하고 직접 호출할 수 있습니다. 2. 시스템의 데이터베이스 관리자는 테이블에 있는 특정 두 개의 데이터 열을 다른 사람에게 제공해야 하지만 다른 데이터는 볼 수 없도록 하려는 경우 이 두 개의 데이터 열만 사용하여 뷰를 구축할 수 있습니다. 를 클릭한 다음 그에게 뷰를 게시합니다.

성능 손실 해결 방법

뷰의 쿼리문을 최적화하세요. 일반적으로 뷰가 뷰에 중첩되거나 하위 쿼리가 매우 복잡하여 계산이 필요한 경우를 제외하고는 직접 쿼리와 쿼리 뷰(SQL 자체가 최적화됩니다) 사이에는 차이가 없습니다. 특별 참고 사항:

뷰를 선택할 때마다 뷰는 생성 규칙(SQL 알고리즘)을 다시 계산합니다. 알고리즘이 복잡하고 데이터 양이 많으면 속도가 느려지므로 속도가 매우 느려집니다. 매번.

또한, 전체 테이블 스캔인 뷰에서는 테이블의 인덱스가 유효하지 않습니다.



데이터베이스는 Oracle이고, 사용된 뷰툴은 Navicat 무료버전입니다.

지정된 데이터를 찾고 보기를 클릭하면 현재의 모든 데이터베이스 보기가 오른쪽에 표시됩니다. 두 번 클릭하면 테이블과 동일한 보기 창이 열립니다.

Ctrl+D 뷰의 SQL 문을 입력하려면 다음을 확인하세요.

관련 무료 학습 권장 사항:

mysql 비디오 튜토리얼

위 내용은 데이터베이스 뷰와 테이블의 차이점은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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