94.

UE5でデータベースを活用する方法

ページの作成
テンプレートを更新

ページの作成

親となるページを選択してください。

ページは必ず何かしらの親ページに紐づきます。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球

子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール

親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!

Unreal Engine 5(UE5)でゲーム開発を行う際、データベースを活用することで、スコア管理やプレイヤー情報の保存、ゲームの進行データの管理などを効率的に行うことができます。

本記事では、UE5でデータベースを使用する方法について、SQLiteを例に挙げて詳しく解説します。

UE5でデータベースを使用するメリット

UE5では、データを管理する方法としてデータテーブルやSaveGameシステムがありますが、データベースを使用することで、より大規模なデータ管理が可能になります。

データベースを使用する主なメリットは以下のとおりです:

  • 大量のデータを高速に管理できる
  • 外部データと連携しやすく、オンラインゲーム開発に適している
  • データの検索・更新が容易
  • ゲームのバージョンアップ時にデータの変更がしやすい

UE5でSQLiteを導入する方法

UE5では、SQLiteを使用することで、手軽にデータベースを活用できます。SQLiteは軽量でファイルベースのデータベース管理システム(DBMS)であり、ローカル環境でのデータ管理に最適です。

1. SQLiteプラグインの導入

UE5にはデフォルトではSQLiteが含まれていないため、サードパーティのプラグインを導入する必要があります。以下の手順でセットアップを行います。

  1. Epic Games Launcherで「マーケットプレイス」を開く
  2. 「SQLite」関連のプラグインを検索し、適切なプラグインをインストール
  3. プロジェクトの「Edit」→「Plugins」を開き、インストールしたプラグインを有効化
  4. エンジンを再起動

プラグインが正しく導入されると、C++やブループリントでSQLiteを操作できるようになります。

2. データベースの作成

SQLiteのデータベースファイル(.db)を作成し、テーブルを定義します。例えば、以下のSQLスクリプトでスコア管理用のテーブルを作成できます。

CREATE TABLE Scores ( ID INTEGER PRIMARY KEY AUTOINCREMENT, PlayerName TEXT, Score INTEGER, Date TEXT );

このテーブルは、プレイヤーの名前、スコア、日時を保存するシンプルな構造になっています。

3. UE5でデータベースに接続

SQLiteプラグインを利用して、UE5のC++コードまたはブループリントでデータベースを操作できます。

(A)C++を使用する方法

SQLiteをC++で利用するには、「sqlite3.h」をインクルードし、データベース接続を作成します。

#include "sqlite3.h" sqlite3* DB; int exit = sqlite3_open("GameDatabase.db", &DB); if (exit != SQLITE_OK) { UE_LOG(LogTemp, Error, TEXT("Database connection failed!")); }

このコードを実行すると、「GameDatabase.db」に接続され、データベースの読み書きが可能になります。

(B)ブループリントを使用する方法

サードパーティの「SQLiteプラグイン」が提供するノードを使えば、ブループリントでSQLクエリを実行できます。例えば、「Execute Query」ノードを使用して、データを挿入することができます。

手順:

  1. 「Execute Query」ノードを作成
  2. 以下のSQLコマンドを実行:

    INSERT INTO Scores (PlayerName, Score, Date) VALUES ('Player1', 1000, '2025-03-01');

  3. 「Commit Transaction」ノードを追加して変更を保存

データの取得と活用

保存したデータを取得し、ゲーム内で表示することも可能です。例えば、ランキングを表示する場合は、以下のようなSQLを実行します。

SELECT PlayerName, Score FROM Scores ORDER BY Score DESC LIMIT 10;

このクエリをブループリントやC++から実行し、取得したデータをUIウィジェットに表示すれば、ゲーム内ランキングを作成できます。

まとめ

UE5でデータベースを活用することで、ゲーム内データの管理がより便利になります。特に、SQLiteを使用することで、シンプルかつ効率的にデータを保存・管理できます。

今回のポイント:

  • データベースを使用すると、大規模なデータ管理が容易になる
  • SQLiteは軽量で、UE5と簡単に連携可能
  • プラグインを導入し、C++またはブループリントで操作できる
  • ランキングやスコア管理など、多くの場面で活用可能

ぜひこの方法を活用して、ゲーム内のデータ管理を効率化してみてください!

ページの作成
テンプレートを更新

ページの作成

親となるページを選択してください。

ページは必ず何かしらの親ページに紐づきます。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球

子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール

親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
  1. 床の上に乗ったらイベントを発生させる方法
  2. OverlapAllDynamicとOverlapAllの違い
  3. タイトル画面を作る方法
  4. サードパーソンテンプレートでのキャラクター表示の仕組みと非表示にする方法
  5. ボタンに文字を記載する方法
  6. Event ActorBeginOverlapとOn Component Begin Overlapの違い
  7. キャラクターに特定のオブジェクトとの当たり判定を付ける
  8. 特定のオブジェクトに触れたとき、キャラクターが倒れるようにする
  9. 動いているオブジェクトに静止しているキャラクターが当たり判定を持たない原因と解決方法
  10. 「On Component Hit」に「Cast To ~」で複数のクラスを指定する方法
  11. ブループリントで途中から親クラスを指定する方法
  12. Blenderファイルをインポートする方法
  13. 鏡を作成する方法
  14. レベルブループリントでキャラクターの出現を設定する方法
  15. サードパーソンテンプレートにおけるキャラクター出現の定義
  16. アイテムに近づいたらボタンを押してイベントを発火させる方法
  17. C++で編集となっているコンポーネントをブループリントで編集する方法
  18. 画面の中央にメッセージを表示する方法
  19. どこからでも呼び出せるカスタムイベントを作成する方法
  20. カスタムイベントに引数を追加する方法
  21. ブループリントでWidgetに引数を追加する方法
  22. ブループリントでBoolean変数の初期値を変更する方法
  23. ブループリントで特定のキーが押された時にイベントを発火させる方法
  24. 「Get Overlapping Actors」から特定のクラスの場合のみ処理を実行する方法
  25. オブジェクトに近づいている間だけメッセージを表示する方法
  26. PCの画面を操作するUIを作る方法
  27. レベルを移動する方法
  28. コンテンツブラウザに画像を追加する方法
  29. マウスを動かせるUIを作成する方法
  30. SetInputMode_UIOnlyを取り消す方法
  31. ウィジェットの画像を選択するとウィジェットを閉じる方法
  32. 特定の画像の上にマウスカーソルを置いたら手マークにする方法
  33. レベルの「基本」テンプレートと「オープンワールド」テンプレートの違い
  34. オブジェクトがアウトライナーで選択できない原因と解決策
  35. PlayerStartを作成する方法
  36. メニュー画面を作成して開く方法
  37. 「Esc」キーを押してメニュー画面を開く方法(ゲーム内の処理は停止する)
  38. イベントの「On Clicked」と「On Pressed」の違い
  39. ウィジェットのボタンに文字を書く方法
  40. Blueprintで「Esc」キーを使ってイベントを発生させる方法
  41. Blueprintで「Cast To」を使い、複数のクラスに対応する方法
  42. Blueprintで特定のクラスのWidgetを閉じる方法
  43. 「Set Input Mode」の種類と使い方
  44. 「Set Game Paused」の使い方と詳細解説
  45. BPでウィジェットのボタンを選択できなくする方法
  46. Blueprintで現在開いているレベルが特定のレベルであるか調べる方法
  47. ウィジェットの背景ブラーについて
  48. プロジェクトの削除方法
  49. Motion Matchingとは?
  50. 「GameMode」と「GameModeBase」の違い
  51. レベルごとにゲームモードを変更する方法
  52. マップに配置したTargetPointを取得する方法
  53. UE5でマップに配置したTargetPointを取得する方法
  54. ブループリントで配列からインデックスを指定して取得する方法
  55. 動的にインスタンスが属するレベルを変更する方法
  56. エディタ上でインスタンスが属するサブレベルを変更する方法
  57. TargetPointにタグをつけて取得する方法
  58. Spawnしたインスタンスがイベントを実行する方法
  59. 特定の時間ごとに処理を実行する方法
  60. とあるアクタから現在開いているレベルの変数にアクセスする方法
  61. 数値をランダムで出力する方法
  62. ThirdPersonテンプレートでキャラクターの移動を歩くように変更する方法
  63. MaxWalkSpeedを変更する方法
  64. しゃがむ動作を導入する方法
  65. キャラクターのアニメーションを設定する方法
  66. Blueprintでプロジェクト全体で共有できるStatic定数の定義方法
  67. プロジェクトを多言語化する方法
  68. 導入済みのプラグインを確認する方法
  69. Motion Matchingの導入と必要なプラグイン
  70. プレイヤーを非表示にする方法
  71. カメラを傾ける角度を制限させる方法
  72. 配列からランダムに重ならない要素を特定の数取得する方法
  73. カメラの映す画面に文字やエフェクトを付ける方法
  74. キャラクターやメッシュを非表示にした際にカメラが移動しなくなる問題の解決方法
  75. Blueprintで指定した確率で処理を分岐させる方法
  76. プライマリーデータアセットを活用する方法
  77. プレイヤーのHPといった変数を定義する最適な場所
  78. カメラに映った画面をスクリーンショットとして保存する方法
  79. スクショ以外の方法でゲーム内のカメラ映像を保存して再表示する方法
  80. HighResShotを使って画像を保存する方法
  81. FrameGrabberをBlueprintで使用する方法
  82. HighResShotで保存した画像のファイル名を取得する方法
  83. SceneCapture2DとFrameGrabberの画像保存方法の比較
  84. SceneCapture2Dを使用して画像を保存・取得する方法
  85. HighResShotとTake High Res Screenshotの違い
  86. ゲーム終了ボタンを作成する方法
  87. セーブするボタンを作成する方法
  88. ロードするボタンを作成する方法
  89. 「Save Game To Slot」の戻り値がfalseになる問題の解決方法
  90. セーブするとセーブファイルの実体がどこに保存されるか
  91. 画面上にメッセージを指定された時間表示させる方法
  92. 「シェーダをコンパイル」を短縮する方法
  93. 「Take High Res Screenshot」実行時に「シェーダをコンパイル」に長時間待たされる問題とその解決策
  94. データベースを活用する方法
  95. Widgetの前後関係を設定する方法
  96. UE5.5がインストールされた環境にUE5.4を追加で導入する方法
  97. World PartitionとWorld Compositionの違い
  98. オープンワールドテンプレートとは?
  99. ポーンをスポーンさせても視点を切り替えない方法
  100. キャラクター同士がすり抜けてしまう問題の解決方法