jsp连接MySQL操作GIS地图数据实现添加point的功能代码
程序员文章站
2023-11-29 20:27:58
index_map.jsp中的代码: 复制代码 代码如下: <%@ page language="java" pageencoding="utf-8"%> &l...
index_map.jsp中的代码:
复制代码 代码如下:
<%@ page language="java" pageencoding="utf-8"%>
<%@ page contenttype="text/html;charset=utf-8"%>
<%
request.setcharacterencoding("utf-8");
response.setcharacterencoding("utf-8");
response.setcontenttype("text/html; charset=utf-8");
%>
<html>
<head>
</head>
<body>
<form action="insert_map.jsp" method="post">
id :<input type = "text" name="id" value="0"/>
名称 :<input type = "text" name="name" value="aaa"/> </br>
电压等级 :<input type = "text" name="voltage_level" value="110kv"/>
经度 :<input type = "text" name="lon" value="121."/>
纬度 :<input type = "text" name="lat" value="28."/>
</br>
<input type = "submit" value="提交"/>
</form>
</body>
</html>
insert_map.jsp的代码:
复制代码 代码如下:
<%@ page language="java" import="java.util.*,java.sql.*" pageencoding="utf-8"%>
<%@ page contenttype="text/html;charset=utf-8"%>
<%
request.setcharacterencoding("utf-8");
response.setcharacterencoding("utf-8");
response.setcontenttype("text/html; charset=utf-8");
%>
<html>
<head>
<title>add message into table </title>
</head>
<body>
<%
string id=request.getparameter("id"); //从表单获得
string name=request.getparameter("name"); //从表单获得
string voltage_level=request.getparameter("voltage_level"); //从表单获得
string lon=request.getparameter("lon"); //从表单获得
string lat=request.getparameter("lat"); //从表单获得
java.util.date date=new java.util.date();
string datetime=new timestamp(date.gettime()).tostring();
try
{
/** 连接数据库参数 **/
string drivername = "com.mysql.jdbc.driver"; //驱动名称
string dbuser = "root"; //mysql用户名
string dbpasswd = "123456"; //mysql密码
string dbname = "map_db"; //数据库名
string connurl = "jdbc:mysql://localhost/" + dbname + "?user=" + dbuser + "&password=" + dbpasswd;
class.forname(drivername).newinstance();
connection conn = drivermanager.getconnection(connurl);
statement stmt = conn.createstatement();
stmt.executequery("set names utf8");
string insert_sql = "insert into biandianzhan_point_tb values('" + id + "','" + name + "','" + voltage_level + "',geometryfromtext('point (" + lon + " " + lat + ")') )";
string query_sql = "select * from biandianzhan_point_tb";
try {
stmt.execute(insert_sql);
}catch(exception e) {
e.printstacktrace();
}
try {
resultset rs = stmt.executequery(query_sql);
while(rs.next()) {
%>
id:<%=rs.getstring("id")%> </br>
名称:<%=rs.getstring("name")%> </br>
电压等级:<%=rs.getstring("voltage_level")%> </br>
经纬度:<%=rs.getstring("the_geom")%> </br> </br>
<%
}
}catch(exception e) {
e.printstacktrace();
}
//rs.close();
stmt.close();
conn.close();
}catch (exception e) {
e.printstacktrace();
}
%>
</body>
</html>
访问index_map.jsp:
提交前数据库的值:
输入测试值并提交,得到如下页面:
数据库的变化如下:
可以看出,在上面的提交后的页面上经纬度是乱码的,原因是the_geom的数据类型是point类型,是几何数据类geometry类中的一个子类,有特定的格式,可能这种特定的格式没能被浏览器识别。我正在考虑的解决方案是将the_geom数据进行剥离,得到两个数值及经纬度。不过可能没这个必要,因为没必要显示这两个值。
总的来说,大功告成了一半吧,呵呵,今天收获很大啊!很开心!
上一篇: 详解Android UI更新的几种方法