Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Menggunakan Lajur Dikira dalam Pengiraan Seterusnya Dalam Pertanyaan Yang Sama?

Bagaimanakah Saya Boleh Menggunakan Lajur Dikira dalam Pengiraan Seterusnya Dalam Pertanyaan Yang Sama?

Barbara Streisand
Barbara Streisandasal
2025-01-05 22:43:41198semak imbas

How Can I Use a Calculated Column in Subsequent Calculations Within the Same Query?

Menggunakan Lajur Dikira untuk Mengira Lajur Lain dalam Paparan Yang Sama

Pertimbangkan situasi di mana anda mempunyai jadual dengan lajur LajurA, LajurB, dan LajurC, dan dalam paparan, anda telah memasukkan lajur terkira calccolumn1 sebagai LajurA ColumnB.

Untuk menggunakan calccolumn1 dalam pengiraan seterusnya dalam pertanyaan yang sama, terdapat dua pendekatan:

1. Pertanyaan Bersarang:

Gunakan pertanyaan bersarang untuk mengira calccolumn1 dahulu, kemudian masukkan pengiraan ini dalam pertanyaan luar untuk pengiraan selanjutnya:

Select
  ColumnA,
  ColumnB,
  calccolumn1,
  calccolumn1 / ColumnC as calccolumn2
From (
  Select
    ColumnA,
    ColumnB,
    ColumnC,
    ColumnA + ColumnB As calccolumn1
  from t42
);

2. Pengiraan Berulang:

Kaedah alternatif ialah mengulangi pengiraan secara eksplisit, terutamanya jika ia tidak intensif pengiraan:

Select
  ColumnA,
  ColumnB,
  ColumnA + ColumnB As calccolumn1,
  (ColumnA + ColumnB) / ColumnC As calccolumn2
from t42;

Dengan mengikuti mana-mana pendekatan, anda boleh memanfaatkan lajur yang dikira untuk melakukan pengiraan tambahan dalam pertanyaan yang sama, membolehkan anda memperoleh cerapan baharu daripada data anda cekap.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan Lajur Dikira dalam Pengiraan Seterusnya Dalam Pertanyaan Yang Sama?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn