近来在做一个有关地理地图方面的东东,以前是用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。
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com