當面臨基於多列(例如DocumentId 和DocumentSessionId)計算表中唯一值的任務時,自然的傾向是採用子查詢方法。但是,這可能會引起對效能優化的擔憂。
使用子查詢的一種替代方法是建立持久計算列。這可以透過散列或連接所需的列來實現,確保可以索引並在其上建立統計資料的確定性結果。
例如,如果相關欄位是 DocumentId 和 DocumentSessionId,則計算欄位名為HashValue 可以使用雜湊函數(例如 SHA1 或MD5)建立:
ALTER TABLE DocumentOutputItems ADD COLUMN HashValue AS SHA1(DocumentId + DocumentSessionId);
一旦計算列被持久化並建立索引,一個不同的此列上的計數將相當於所需的結果:
SELECT COUNT(DISTINCT HashValue) FROM DocumentOutputItems;
透過使用持久計算列,您可以利用索引和統計資料來提高效能,從而無需子查詢。
以上是如何有效計算資料庫表中多個列的唯一組合?的詳細內容。更多資訊請關注PHP中文網其他相關文章!