Android通过PHP连接MySQL(传值查询)

和  Android通过PHP连接MySQL(读取)   类似,界面不变,把  AndroidTestActivity.java   修改为:

select.php

<?php
mysql_connect("127.0.0.1","root","123456");
mysql_query("SET NAMES utf8");
mysql_select_db("test");

$sql=mysql_query("select * from teacher where id='".$_REQUEST['id']."' and name='".$_REQUEST['name']."'");
while($row=mysql_fetch_assoc($sql))
$output[]=$row;
print(json_encode($output));
mysql_close();
?>

package com.knight.android.MySQL;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.Activity;
import android.net.ParseException;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;

public class Android_MySQLActivity extends Activity {
JSONArray jArray;
String result = null;
InputStream is = null;
StringBuilder sb=null;
@Override
public void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.main);
      Button b1 = (Button) findViewById(R.id.button1);
      b1.setOnClickListener(new Button.OnClickListener() {
      @Override
      public void onClick(View v) {
      // TODO Auto-generated method stub
      EditText tv = (EditText) findViewById(R.id.editView);
       ArrayList nameValuePairs = new ArrayList();
    nameValuePairs.add(new BasicNameValuePair("id","3"));
    nameValuePairs.add(new BasicNameValuePair("name","Guo"));
      //http post
      try{
              HttpClient httpclient = new DefaultHttpClient();
              HttpPost httppost = new HttpPost("http://175.186.54.10/select.php");
         httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
              HttpResponse response = httpclient.execute(httppost);
              HttpEntity entity = response.getEntity();
              is = entity.getContent();
      }catch(Exception e){
              Log.e("log_tag", "Error in http connection"+e.toString());
      }
   //convert response to string
      try{
              BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
              sb = new StringBuilder();
              sb.append(reader.readLine() + "\n");
 
              String line=null;
              while ((line = reader.readLine()) != null) {
                     sb.append(line + "\n");
              }
              is.close();
              result=sb.toString();
      }catch(Exception e){
              Log.e("log_tag", "Error converting result "+e.toString());
      }
      //paring data
      int ct_id;
      String ct_name;
      try{
              jArray = new JSONArray(result);
              JSONObject json_data=null;
             
              for(int i=0;i<jArray.length();i++){
                     json_data = jArray.getJSONObject(i);
                     ct_id=json_data.getInt("id");
                     ct_name=json_data.getString("name");
                      tv.append(ct_name+" \n");
              }
      }catch(JSONException e1){
              //    Toast.makeText(getBaseContext(), "No City Found" ,Toast.LENGTH_LONG).show();
      } catch (ParseException e1) {
              e1.printStackTrace();
      }
}
});
}
}

 

转发来自: http://blog.sina.com.cn/s/blog_6923201d01012rd7.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值