近来在做一个有关地理地图方面的东东,以前是用sql server作为数据库,现在改为mysql,发现MapXtreme-4.8.0不能读取数据库中的经纬度值。找找了很久最后发现是别名搞得鬼,但是在sql server 查询时可以使用as 。
下面是代码片段1:
query = "SELECT jz_jd, jz_wd, jz_bh FROM t_jz"; // 设置SQL查询串
layername = "基 站"; // 设置图层名称
mymap = insertDBLayer(mymap, query, layername, Color.red, "jz theme", String.valueOf((char) 80),"jz"); // 插入XY数据图层并设置图层样式
片段2:
// 插入XY layer函数
public MapJ insertDBLayer(MapJ mymap, String query, String layername, Color mycolor, String themeName, String symbol,String type) {
XYDataProviderHelper xyDPHelper = new XYDataProviderHelper(driverName, databaseconn, dbusername, dbpassword);
String[] idColumns = { type+"_bh" };
// Table information
String xCol = type+"_jd";
String yCol = type+"_wd";
String rendCol = null;
RenditionType perFeatureType = RenditionType.none;
String labelRendCol = null;
RenditionType perFeatureLabelType = RenditionType.none;
CoordSys csys = CoordSys.longLatWGS84;
XYTableDescHelper queryTDH = new XYTableDescHelper(query, idColumns, xCol, yCol, rendCol, perFeatureType, labelRendCol, perFeatureLabelType, csys);
try {
MapXtremeDataProviderRef mxtDPRef = new MapXtremeDataProviderRef(xyDPHelper, mapxtremeurl);
mymap.getLayers().insertLayer(mxtDPRef, queryTDH, 0, layername);
if (resetzoom < 20000)
setLayerStyle(mymap, layername, mycolor, themeName, symbol, 2); // 设置符号样式
else
setLayerStyle(mymap, layername, mycolor, themeName, symbol, 1); // 设置符号样式
String idname = type+"_bh";
setLayerLabel(mymap, layername, idname); // 设置标注样式
} catch (Exception e) {
}
return mymap;
}
以上代码是可以正常运行的。
如果query = "SELECT jz_jd as jd, jz_wd as wd, jz_bh as Col_name FROM t_jz"; // 设置SQL查询串
则无法运行了。但在sql server下可以正常运行。
另外在mysql中,经纬度坐标的值的类型为double或者decimal,不能为float。