数学リーグのデータを、両方ともJavaで記述された2つの異なるシステム間で移動する必要があります。データは、MySQLデータベースに裏打ちされたJava Webアプリケーションから取得されます。このデータベースには、学校と生徒のテーブルがあり、どちらも一意のID番号を持っています。データは、2月のトーナメントイベントの日にスコアを記録するために使用されるデスクトップクライアントでオフラインで読み取ることができる形式にエクスポートする必要があります。
クライアントは現在、データをCSVファイルとして保存します。これには、「データベース」全体をExcelにロードして、すべてのチームのすべての学生のスコアを表示できるという優れた利点があります。昨年、この形式はデータが破損したために問題がありました(スコアカードに間違ったチーム番号を入力した後、データ入力チームがシステムに不正なデータを入力したため、データ入力に冗長性がありました)
より構造化された方法でデータを保存するようにクライアントを更新し、CSVファイルをエクスポート専用の機能として残したいと思います。私はXMLシリアル化に最も精通しているので、XMLシリアル化を選択します。しかし、JSONまたはYAMLの利点について知りたいです。同時に、デスクトップクライアントが読み取れる形式にデータを移動できるようにするエクスポート機能をWebアプリケーションに追加する必要があります。Webアプリケーションのユーザー(数学チームのコーチ)は、トーナメントに参加する学生を選択し、クライアントが読み取れるファイルをダウンロードします。データ構造は次のようになります。
team id
school name
student1
student2
student3
student4
student5
各学生オブジェクトは、ID番号、名前、およびスコアのいくつかのフィールドで構成されています。
ここではストレートXMLが最も理にかなっていますか、それとも他の何かが簡単ですか?