起動・前提準備
初期テーブル、依存状態、定期処理の点灯など、このクラスが動き始める前提をまとめています。
Minecraft UUID と Discord User ID の紐付けをDBに保存するDAO。
com.example.rankingplugin.discordlinkdiscordlink/DiscordLinkDao.javaclassMinecraft UUID と Discord User ID の紐付けをDBに保存するDAO。 ★ server_id でサーバー単位に切り分け
Minecraft UUID と Discord User ID の紐付けをDBに保存するDAO。discordlink パッケージの 小〜中規模クラスで、責務境界の要点を確認する起点です。全面展開版では、他の重点クラスと同じ章立てで読めるように補強しています。
DiscordLinkDaoensureTablesloadAllLinkstryMigrateLegacygetDiscordIdgetUuidByDiscordIdupsertLink初期テーブル、依存状態、定期処理の点灯など、このクラスが動き始める前提をまとめています。
外部から呼ばれる公開メソッドや、対象プレイヤー・対象データ・対象ワールドを引き当てる経路です。
DB テーブルとの境界です。スキーマ変更や保存漏れの切り分けはここから行います。
このクラスが前提状態を揃え、外部から利用可能な形まで立ち上がる流れです。新規依存の追加や起動失敗の調査はまずここから追います。
イベント受理、判定、状態更新、通知までの主経路です。体感不具合や想定外の分岐はこの流れのどこで止まるかを見ると切り分けやすいです。
結果を保持し、必要なら永続化し、最後に掃除まで行う出口です。画面更新だけ合って保存が壊れるケースや残骸が残るケースの確認に向きます。
SQL 文字列から抽出できた主要テーブルです。スキーマ変更時の確認用です。
| Visibility | Type | Name | 役割 |
|---|---|---|---|
public | String | TABLE_LINK | TABLE_LINK の状態を保持します。 |
private | DataSource | ds | DB 接続元を保持します。 |
| Signature | 説明 | 主要呼び出し |
|---|---|---|
public DiscordLinkDao(DataSource ds) | 依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。 | 主要呼び出しなし |
| Name | Visibility | Kind | 説明 |
|---|---|---|---|
| DiscordLinkDao | public | コンストラクタ | 依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。 |
| ensureTables | public | メソッド | 必要なテーブル・状態・前提条件が揃っているかを確認し、不足分を補います。 |
| tryMigrateLegacy | private | メソッド | DB への問い合わせまたは更新処理を担当します。 |
| loadAllLinks | public | メソッド | 必要な状態を取得し、呼び出し側で利用しやすい形へ返します。 |
| getDiscordId | public | メソッド | 必要な状態を取得し、呼び出し側で利用しやすい形へ返します。 |
| getUuidByDiscordId | public | メソッド | 必要な状態を取得し、呼び出し側で利用しやすい形へ返します。 |
| upsertLink | public | メソッド | 既存の紐付けがあれば上書きする(uuid / discord_id のどちらが既に使われていても更新)。 |
public DiscordLinkDao(DataSource ds)依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。
DataSource dsなし
public void ensureTables(String serverIdForLegacy) throws SQLException必要なテーブル・状態・前提条件が揃っているかを確認し、不足分を補います。
String serverIdForLegacySQLException
private void tryMigrateLegacy(String serverIdForLegacy)DB への問い合わせまたは更新処理を担当します。
String serverIdForLegacyなし
public Map<UUID, Long> loadAllLinks(String serverId) throws SQLException必要な状態を取得し、呼び出し側で利用しやすい形へ返します。
String serverIdSQLException
public Optional<Long> getDiscordId(String serverId, UUID uuid) throws SQLException必要な状態を取得し、呼び出し側で利用しやすい形へ返します。
String serverIdUUID uuidSQLException
public Optional<UUID> getUuidByDiscordId(String serverId, long discordId) throws SQLException必要な状態を取得し、呼び出し側で利用しやすい形へ返します。
String serverIdlong discordIdSQLException
public void upsertLink(String serverId, UUID uuid, long discordId) throws SQLException既存の紐付けがあれば上書きする(uuid / discord_id のどちらが既に使われていても更新)。
String serverIdUUID uuidlong discordIdSQLException
loadAllLinks → getConnection → prepareStatement → setString → executeQuery → nextensureTables → uq_srv_discord → getConnection → prepareStatement → execute → tryMigrateLegacygetDiscordId → getConnection → prepareStatement → setString → toString → executeQuerygetUuidByDiscordId → getConnection → prepareStatement → setString → setLong → executeQuerytryMigrateLegacy → getConnection → prepareStatement → executeQuery → execute → setString