>데이터 베이스 >MySQL 튜토리얼 >MySQL의 다른 열을 기반으로 열을 효율적으로 계산하려면 어떻게 해야 합니까?

MySQL의 다른 열을 기반으로 열을 효율적으로 계산하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-17 07:42:10149검색

How Can I Efficiently Calculate a Column Based on Other Columns in MySQL?

MySQL에서 다른 열을 기반으로 효율적으로 열을 계산하는 방법

MySQL 5.7.6 이상에는 생성된 열(Generated Columns)이 도입되었습니다. 이는 동일한 테이블의 기존 열을 기반으로 새 열의 값을 자동으로 계산하는 효율적인 방법입니다. 뷰와 달리 생성된 열은 테이블 정의의 일부이며 소스 열이 변경되면 자동으로 업데이트됩니다.

가상 생성 열 및 저장된 생성 열

생성된 열은 가상이거나 저장될 수 있습니다.

  • 가상: 테이블 레코드를 읽을 때 동적으로 계산됩니다.
  • 저장: 테이블 레코드가 작성되거나 업데이트될 때 계산됩니다.

이 경우 새 레코드를 삽입하거나 기존 레코드를 업데이트할 때 계산된 값을 즉시 사용할 수 있어야 하므로 생성된 열을 저장하는 것이 더 적합합니다.

스토리지를 활용한 생성 컬럼 구현

테이블에 pricequantity라는 두 개의 열이 있고 값이 amountprice의 곱인 새 열 quantity을 추가하려고 한다고 가정합니다. 다음 SQL 문을 사용하여 스토리지 생성 열을 생성할 수 있습니다.

<code class="language-sql">CREATE TABLE order_details (
  price DOUBLE,
  quantity INT,
  amount DOUBLE AS (price * quantity) STORED
);</code>

열이 생성되면 amount이 테이블의 각 행에 대해 자동으로 계산되어 저장됩니다. price 또는 quantity을 변경하면 amount 업데이트가 실행됩니다.

테이블 데이터가 포함된 예

샘플 데이터를 삽입한 후:

<code class="language-sql">INSERT INTO order_details (price, quantity) VALUES(100,1),(300,4),(60,8);</code>

테이블은 다음과 같습니다.

id price quantity amount
1 100 1 100
2 300 4 1200
3 60 8 480

amount 필요에 따라 열이 자동으로 채워지고 업데이트되므로 계산된 값에 효율적으로 액세스할 수 있습니다.

위 내용은 MySQL의 다른 열을 기반으로 열을 효율적으로 계산하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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