Web サービス関数を作成しました。
@GET
@Path("getusers/")
@Produces({"application/xml","application/json"})
public Object getUsers()
{
String distanceQuery="SELECT UGL.user_id,UP.fname,UGL.mlatitude,UGL.mlogitude,UGL.mlogitude from user_gps_location UGL,user_profile UP where UGL.user_id=UP.user_id";
Query queryResult=em.createNativeQuery(distanceQuery);
userList=queryResult.getResultList();
return userList;
}
この関数は結果のリストを返します: application/json オプションを選択してブラウザでテストすると、正常に動作します:
結果:
[[1,"Ankit",37.334542,-121.890821,-121.890821],
[1,"Ankit",37.337749,-121.886702,-121.886702],
[1,"Ankit",37.336453,-121.884985,-121.884985],
[1,"Ankit",37.336453,-121.884985,-121.884985],
[1,"Ankit",37.336453,-121.884985,-121.884985],
[1,"Ankit",32.727798,-117.15683,-117.15683],
[1,"Ankit",37.334541666666674,-121.89081999999999,-121.89081999999999],
[1,"Ankit",37.33774833333334,-121.88670166666667,-121.88670166666667],
[1,"Ankit",37.33774833333334,-121.88670166666667,-121.88670166666667],
[1,"Ankit",37.334541666666674,-121.89081999999999,-121.89081999999999],
[1,"Ankit",37.334541666666674,-121.89081999999999,-121.89081999999999],
[1,"Ankit",37.33774833333334,-121.88670166666667,-121.88670166666667],
[2,"Niharika",37.334541666666674,-121.88670166666667,-121.88670166666667],
[2,"Niharika",37.334541666666674,-121.88670166666667,-121.88670166666667]]
しかし、「application/xml」を選択すると、エラーが発生します。
javax.ws.rs.WebApplicationException: com.sun.jersey.api.MessageException: A message body writer for Java class java.util.Vector, and Java type class java.util.Vector, and MIME media type application/xml was not found
誰でも私を助けて、何が悪いのか教えてもらえますか?
また、以下のような整形式の結果を返すにはどうすればよいですか?
<id>1</id>
<name>Ankit</name>
クラスを使用する必要があることはわかっていますが、これはネイティブクエリであり、2 つのテーブルを使用し、結果リストも返すため、その方法がわかりません。