Skip to content

DailyDataPerUnit テーブル(db2023)のスキーマ前提

概要

日別データ(台単位)を格納するテーブルは DatabaseTableConstants::DAILY_DATA(値: db2023)で、実際のテーブル名は環境ごとの WordPress テーブル接頭辞を付与した {$wpdb->prefix}db2023 となる(例: 接頭辞が wp_ の場合は wp_db2023)。

差枚(samai): マイナス値を数値(INT 型)で格納する場合、samai カラムは SIGNED である必要がある(INT 型で UNSIGNED のまま負の値を INSERT すると MySQL が 0 に変換する)。

DailyDataPerUnitRepository::insert_or_update_batch()INSERT ... ON DUPLICATE KEY UPDATE を使用しており、一意キー (DAY, dainum, hall) が DB に存在する前提で動作する。本ドキュメントはその制約の確認方法と、未定義時の対応方針をまとめる。

前提とする一意制約

  • カラムの組み合わせ: (DAY, dainum, hall)
  • 制約種別: UNIQUE KEY または PRIMARY KEY のいずれかがテーブルに定義されていること

スキーマ確認方法

本番または開発 DB に接続し、以下いずれかで制約の有無を確認する。以下ではテーブル名を {prefix}db2023 で表す。{prefix} は自環境の WordPress テーブル接頭辞(例: wp_)に読み替えて実行すること。

方法1: SHOW CREATE TABLE

sql
SHOW CREATE TABLE `{prefix}db2023`;

出力に UNIQUE KEY または PRIMARY KEYDAY, dainum, hall が含まれることを確認する。

方法2: information_schema

sql
SELECT `INDEX_NAME`, `COLUMN_NAME`, `NON_UNIQUE`
FROM information_schema.STATISTICS
WHERE `TABLE_SCHEMA` = DATABASE()
  AND `TABLE_NAME` = '{prefix}db2023'
ORDER BY `INDEX_NAME`, `SEQ_IN_INDEX`;

(DAY, dainum, hall) の組み合わせで一意制約(NON_UNIQUE = 0)または PRIMARY が存在するかを確認する。

関連コード

制約が未定義の場合の対応

スキーマ確認の結果、(DAY, dainum, hall) の UNIQUE KEY / PRIMARY KEY が存在しない場合は、以下を検討する。実際のマイグレーション実施は別 Issue に切り出してよい(Issue #686 の備考に従う)。

1. 既存データの重複調査

重複行が存在すると UNIQUE 追加時にエラーになるため、事前に確認する。

sql
SELECT `DAY`, `dainum`, `hall`, COUNT(*) AS cnt
FROM `{prefix}db2023`
GROUP BY `DAY`, `dainum`, `hall`
HAVING COUNT(*) > 1;

結果が 0 件であることを確認したうえで UNIQUE 追加を検討する。

2. UNIQUE KEY 追加のマイグレーション方針

  • 重複が存在する場合は、データ整理(どれを残すかの方針と SQL)を別途検討する。
  • 重複が存在しない場合、以下のように UNIQUE KEY を追加する。
sql
ALTER TABLE `{prefix}db2023`
ADD UNIQUE KEY uk_day_dainum_hall (`DAY`, `dainum`, `hall`);
  • 本番適用時はバックアップ取得・メンテナンス窓の確保を行う。
  • スキーマ変更は WordPress 側の Installer(core_src/Infrastructure/Database/dbDelta)で配布する方針とし、本番での手動 DDL が必要な場合は当該 *Installer.php の定義と手順書をドキュメント化することを推奨する。

3. ドキュメントの記載

制約が未定義であることが判明した場合は、本ドキュメントの「前提とする一意制約」の直後に「現状は未定義。insert_or_update_batch の期待動作のため、制約追加を推奨する。」などの注記を追記し、上記「制約が未定義の場合の対応」セクションとあわせて運用する。