Android通过json向MySQL中读写数据的方法详解【读取篇】

本文实例讲述了Android通过json向MySQL中读取数据的方法。分享给大家供大家参考,具体如下:

首先 要定义几个解析json的方法parseJsonMulti,代码如下:

private void parseJsonMulti(String strResult) { try { Log.v("strResult11","strResult11="+strResult); int index=strResult.indexOf("["); if(index>0) strResult=strResult.substring(index, strResult.length()); Log.v("strResult22","strResult22="+strResult); wifiMapData = new JSONArray(strResult); Log.v("wifiMapDataLength",""+wifiMapData.length()); for(int i = 0; i < wifiMapData.length() ; i++){///基站信息处理 ///MapData m=new MapData(1, dLat[5], dLong[5], 10, 20, 300, 500, 105, "教1", 1, 1, 4); JSONObject jsonObject = wifiMapData.getJSONObject(i); int id=Integer.parseInt(jsonObject.getString("id")); //id // if(jsonObject.isNull("mac_address")) mac_address=""; String mac_address = jsonObject.getString("mac_address");//wifi的mac地址 String wifi_name=jsonObject.getString("wifi_name"); //ssid if(!jsonObject.isNull("lat")&&!jsonObject.isNull("lon")){ lat= Double.valueOf(jsonObject.getString("lat"));//纬度 lon=Double.valueOf(jsonObject.getString("lon"));//经度 } String location_name=jsonObject.getString("location_name"); //ssid String wifi_adds = jsonObject.getString("wifi_adds");//wifi地址 具体到多少路多少号 String area = jsonObject.getString("area");//北京的什么区 String location_type = jsonObject.getString("location_type");//地点是个什么类型的,写字楼?? String ap_free = jsonObject.getString("ap_free");//ap是否免费 String category = jsonObject.getString("category");//ap是否免费 String password = jsonObject.getString("password");//ap是否免费 String capabilities = jsonObject.getString("capabilities");//ap是否免费 String user_score = jsonObject.getString("user_score");//ap是否免费 String NW_score = jsonObject.getString("NW_score");//ap是否免费 } // tvJson.setText(s); } catch (JSONException e) { System.out.println("Jsons parse error !"); e.printStackTrace(); } }

再定义一个向MySql发送http请求的方法connServerForResult,代码如下:

private String connServerForResult(String strUrl) { // HttpGet对象 HttpGet httpRequest = new HttpGet(strUrl); String strResult = ""; try { // HttpClient对象 HttpClient httpClient = new DefaultHttpClient(); // 获得HttpResponse对象 HttpResponse httpResponse = httpClient.execute(httpRequest); if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { // 取得返回的数据 strResult = EntityUtils.toString(httpResponse.getEntity()); } } catch (ClientProtocolException e) { Toast.makeText(Setting.this, "protocol error", Toast.LENGTH_SHORT).show(); e.printStackTrace(); } catch (IOException e) { Toast.makeText(Setting.this, "IO error", Toast.LENGTH_SHORT).show(); e.printStackTrace(); } return strResult; }

然后就是在主程序中调用这两个方法:代码如下

String strUrl1 = "http://192.168.1.2/call_for_wifiMapData.php"; //获得返回的Json字符串 String strResult1 = connServerForResult(strUrl1); Log.v("strResult1",strResult1); parseJsonMulti(strResult1);

只有几句话而已,php同样要替换成你自己的文件路径,

php代码如下:

<?php $jsonArrayString = $_POST["jsonArrayString"]; $jsonString = $_POST["jsonString"]; $objArray=json_decode($jsonArrayString,true); $obj=json_decode($jsonString); $lon = (float)$obj->lon; $lat = (float)$obj->lat; $distance=(float)$obj->distance; if($lat==null||$lat==0){ $lat=39.990132; $lon=116.332224; $distance=100000; } ////将cell表中与点(lat,lon)距离小于distance的点打包回来 $con = mysql_connect("localhost","root",null); if (!$con) { die('Could not connect:'.mysql_error() ); } mysql_select_db("a0722152915", $con); mysql_query("set names 'utf8'"); $sqlfind = "select * from `wifi`"; $resultFind = mysql_query($sqlfind, $con); $length=mysql_num_rows($resultFind); $arr=array(); $j=0; for($i=0;$i<$length;$i++) { $row = mysql_fetch_array($resultFind); $arr[$j]['id'] = $row['id']; $arr[$j]['mac_address']=$row['mac_address']; $arr[$j]['wifi_name']=$row['wifi_name']; $arr[$j]['lat']=$row['gps_lat']; $arr[$j]['lon']=$row['gps_lon']; $arr[$j]['location_name']=$row['location_name']; $arr[$j]['wifi_adds']=$row['wifi_adds']; $arr[$j]['area']=$row['area']; $arr[$j]['location_type']=$row['location_type']; $arr[$j]['ap_free']=$row['ap_free']; $arr[$j]['category']=$row['category']; $arr[$j]['password']=$row['password']; $arr[$j]['capabilities']=$row['capabilities']; $arr[$j]['user_score']=$row['user_score']; $arr[$j]['NW_score']=$row['NW_score']; $j++; } //print_r($arr);\ echo json_encode($arr); ?>

还有一点需要注意,就是如果你的终端上的操作系统是android4.0以上的,要添加上那一段代码,上一篇《Android通过json向MySQL中读写数据的方法详解【写入篇】》有写,这里略过

如此一来,可以从MySql中成功地将数据读取下来

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android操作json格式数据技巧总结》、《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

时间: 2017-12-04

Android通过json向MySQL中读写数据的方法详解【读取篇】的相关文章

Android通过json向MySQL中读写数据的方法详解【读取篇】_Android

本文实例讲述了Android通过json向MySQL中读取数据的方法.分享给大家供大家参考,具体如下: 首先 要定义几个解析json的方法parseJsonMulti,代码如下: private void parseJsonMulti(String strResult) { try { Log.v("strResult11","strResult11="+strResult); int index=strResult.indexOf("[");

Android通过json向MySQL中读写数据的方法详解【写入篇】_Android

本文实例讲述了Android通过json向MySQL中写入数据的方法.分享给大家供大家参考,具体如下: 先说一下如何通过json将Android程序中的数据上传到MySQL中: 首先定义一个类JSONParser.Java类,将json上传数据的方法封装好,可以直接在主程序中调用该类,代码如下 public class JSONParser { static InputStream is = null; static JSONObject jObj = null; static String j

Android通过json向MySQL中读写数据的方法详解【写入篇】

本文实例讲述了Android通过json向MySQL中写入数据的方法.分享给大家供大家参考,具体如下: 先说一下如何通过json将Android程序中的数据上传到MySQL中: 首先定义一个类JSONParser.Java类,将json上传数据的方法封装好,可以直接在主程序中调用该类,代码如下 public class JSONParser { static InputStream is = null; static JSONObject jObj = null; static String j

MySQL中mysqldump工具使用方法详解

导出要用到MySQL的mysqldump工具,基本用法是:    代码如下 复制代码 shell> mysqldump [OPTIONS] database [tables]   如果你不给定任何表,整个数据库将被导出.   通过执行mysqldump --help,你能得到你mysqldump的版本支持的选项表.   注意,如果你运行mysqldump没有--quick或--opt选项,mysqldump将在导出结果前装载整个结果集到内存中,如果你正在导出一个大的数据库,这将可能是一个问题. 

MySQL导出备份(数据导出)方法详解

表数据导出到一个文本文件最简单的方法是使用SELECT... INTO OUTFILE语句的查询结果直接导出到一个文件在服务器主机上. 导出数据的SELECT...INTO OUTFILE声明: 这句话的语法结合了常规的SELECT INTO OUTFILE文件名的末尾.默认的输出格式是相同的LOAD DATA,所以下面的语句导出tutorials_tbl的表制表符分隔的,换行结尾的文件到/tmp/tutorials.txt:  代码如下 复制代码 mysql> SELECT * FROM tu

在php和MySql中计算时间差的方法详解

 在php中计算时间差有时候是件麻烦的事!不过只要你掌握了日期时间函数的用法那这些也就变的简单了. 最近在研究自己爱围脖的时候就要计算到恋爱天数,这需要php根据每天的日期进行计算,下面就来谈谈实现这种日期计算的几种方法: (1) 如果有数据库就很容易了!若是MSSQL可以使用触发器!用专门计算日期差的函数datediff()便可!若是MYSQL那就用两个日期字段的差值计算的计算结果保存在另一个数值型字段中!用时调用便可! (2)如果没有数据库,那就得完全用php的时间日期函数! 下面主要说明之

在php和MySql中计算时间差的方法详解_php技巧

在php中计算时间差有时候是件麻烦的事!不过只要你掌握了日期时间函数的用法那这些也就变的简单了. 最近在研究自己爱围脖的时候就要计算到恋爱天数,这需要php根据每天的日期进行计算,下面就来谈谈实现这种日期计算的几种方法: (1) 如果有数据库就很容易了!若是MSSQL可以使用触发器!用专门计算日期差的函数datediff()便可!若是MYSQL那就用两个日期字段的差值计算的计算结果保存在另一个数值型字段中!用时调用便可! (2)如果没有数据库,那就得完全用php的时间日期函数! 下面主要说明之:

Mysql中limit的用法方法详解与注意事项_php技巧

 在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,这个时候怎么办呢?不用担心, mysql已经为我们提供了这样一个功能. SELECT * FROM table  LIMIT [offset,] rows | rows OFFSET offset LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数.LIMIT 接受一个或两个数字参数.参数必须 是一个整数常量.如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回 记录行的最大数目.初始记录行的

mysql中日期比较大小方法详解

假如有个表product有个字段add_time,它的数据类型为datetime,有人可能会这样写sql:  代码如下 复制代码 select * from product where add_time = '2013-01-12' 对于这种语句,如果你存储的格式是YY-mm-dd是这样的,那么OK,如果你存储的格式是:2013-01-12 23:23:56这种格式你就悲剧了,这是你就可以使用DATE()函数用来返回日期的部分,所以这条sql应该如下处理:  代码如下 复制代码 select *