สอบถามเรื่องการ SELECT ... WHERE LIKE ค้นหาค่าจาก 2 ฟิลด์ แล้วดึง เรดคอดนั้นออกมา
พอดีว่าผมต้องการดึง เรดคอด นั้นๆออกมา จากการค้นหา ฟิว Start กับ End
ผมเขียนโค้ดเพื่อค้นหาจาก Start ได้แล้ว แต่อยากให้มันค้นหาจาก Start และ End โดนต้องใส่ 2 ค่า จึงจะดึง เรดคอดนั้นออกมาอะคับ
Code (PHP)
<?php
include ("connect.php");
// $_POST["txtKeyword"] = "a"; // for Sample
$strKeyword = $_POST["txtKeyword2"];
$strSQL = " bus.Nobus, bus.Color,bus.Time,bus.Category,bus.Detail,road.Start, road.End,road.Price,road.Totalscore,road.Nobus FROM bus INNER JOIN road ON bus.Nobus=road.Nobus WHERE 1 = Start LIKE '%".$strKeyword2."%'";
$objQuery = mysql_query($strSQL);
$intNumField = mysql_num_fields($objQuery);
$resultArray = array();
while($obResult = mysql_fetch_array($objQuery))
{
$arrCol = array();
for($i=0;$i<$intNumField;$i++)
{
$arrCol[mysql_field_name($objQuery,$i)] = $obResult[$i];
}
array_push($resultArray,$arrCol);
}
echo json_encode($resultArray);
?>
ผมควรจะเพิ่มตรงไหนยังไง รบกวนพี่ๆด้วยครับ
ขอบคุณครับ Tag : PHP, MySQL, Android
Date :
2015-04-05 01:41:42
By :
dewzaa186
View :
745
Reply :
5
Code (PHP)
#ส่งค่ามาทั้งสองค่า แล้วรับค่าไว้
$startx = $_REQUEST['start'];
$endx= $_REQUEST['end'];
$query = mysql_query("SELECT a.*,b.Start, b.End,b.Price,b.Totalscore,b.Nobus FROM bus AS a LEFT JOIN road AS b ON a.Nobus = b.Nobus WHERE b.Start LIKE '%$startx%' AND b.End LIKE '%$endx%' ");
if (!$query) {
echo mysql_error();
exit();
}
หรือไม่ก็ลองเอาคำสั่ง ไปรันดู ใน phpmyadmin ดูก่อนครับ ว่ามีค่าอะไรออกมาใหม
Code (PHP)
SELECT a.*,b.Start, b.End,b.Price,b.Totalscore,b.Nobus FROM bus AS a LEFT JOIN road AS b ON a.Nobus = b.Nobus WHERE b.Start LIKE '%มีน%' AND b.End LIKE '%สมร%'
Date :
2015-04-05 05:04:56
By :
deawx
ได้ตามที่ต้องการเลยครับ
ขอบคุณมากๆเลยครับ
พอดีผมไปผ่อนผันทหารเลยกลับมาขอบคุณช้า
กำลังจะสอบวันอังคาร แล้วติดโค้ดตัวนี้พอดี
ขอบคุณมากๆจิงๆค้าบบบ
Date :
2015-04-05 16:42:02
By :
dewzaa186
แล้วถ้าผมจะสร้างฟอร์มเพื่อ Decode นี่ ควรเพิ่มตรงไหนหรอครับ
search_road.xml ฟอร์มค้นหา
Code (XML)
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/tableLayout2"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#3b92d1">
<TableRow
android:id="@+id/tableRow2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TextView
android:id="@+id/textViewroad1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_span="1"
android:gravity="center"
android:text="Search Start : "
android:textAppearance="?android:attr/textAppearanceMedium" />
<EditText
android:id="@+id/editTextroad1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:ems="4" >
</EditText>
<Button
android:id="@+id/button33"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="OK" />
</TableRow>
<View
android:layout_height="1dip"
android:background="#CCCCCC" />
<LinearLayout
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_weight="0.1">
<ListView
android:id="@+id/listView1"
android:layout_width="match_parent"
android:layout_height="wrap_content">
</ListView>
</LinearLayout>
</TableLayout>
Road_Search.java โค้ดjava ฟอร์ม xml ครับ
Code (Android-Java)
package masterung.app.app_bus;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.StatusLine;
import org.apache.http.client.ClientProtocolException;
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.os.Bundle;
import android.os.StrictMode;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.util.Log;
import android.view.View;
import android.view.Menu;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.SimpleAdapter;
public class Road_Search extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.search_road);
// Permission StrictMode
if (android.os.Build.VERSION.SDK_INT > 9) {
StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);
}
final Button btn1 = (Button) findViewById(R.id.button33);
// Perform action on click
btn1.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
SearchData();
}
});
}
public void SearchData()
{
// listView1
final ListView lisView1 = (ListView)findViewById(R.id.listView1);
// editText1
final EditText inputText2 = (EditText)findViewById(R.id.editTextroad1);
String url = "http://www.walkerengineering.co.th/bus/API_Road.php";
// Paste Parameters
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("start", inputText2.getText().toString()));
try {
JSONArray data = new JSONArray(getJSONUrl(url,params));
final ArrayList<HashMap<String, String>> MyArrList = new ArrayList<HashMap<String, String>>();
HashMap<String, String> map;
for(int i = 0; i < data.length(); i++){
JSONObject c = data.getJSONObject(i);
map = new HashMap<String, String>();
map.put("Nobus", c.getString("Nobus"));
map.put("Color", c.getString("Color"));
map.put("Time", c.getString("Time"));
map.put("Category", c.getString("Category"));
map.put("Detail", c.getString("Detail"));
MyArrList.add(map);
}
SimpleAdapter sAdap;
sAdap = new SimpleAdapter(Road_Search.this, MyArrList, R.layout.search_bus_column,
new String[] {"Nobus", "Color", "Time", "Category", "Detail"}, new int[] {R.id.Nobus, R.id.Color, R.id.Time, R.id.Category, R.id.Detail});
lisView1.setAdapter(sAdap);
final AlertDialog.Builder viewDetail = new AlertDialog.Builder(this);
// OnClick Item
lisView1.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> myAdapter, View myView,
int position, long mylng) {
String strNobus = MyArrList.get(position).get("Nobus")
.toString();
String sColor = MyArrList.get(position).get("Color")
.toString();
String strTime = MyArrList.get(position).get("Time")
.toString();
String strCategory = MyArrList.get(position).get("Category")
.toString();
String strDetail = MyArrList.get(position).get("Detail")
.toString();
viewDetail.setIcon(android.R.drawable.btn_star_big_on);
viewDetail.setTitle("B Detail");
viewDetail.setMessage("เบอร์รถเมล์: " + strNobus + "\n"
+ "สี : " + sColor + "\n"
+ "เวลารถวิ่ง : " + strTime + "\n"
+ "ประเภทรถ : " + strCategory + "\n"
+ "รายละเอียด : " + strDetail);
viewDetail.setPositiveButton("OK",
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
// TODO Auto-generated method stub
dialog.dismiss();
}
});
viewDetail.show();
}
});
} catch (JSONException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public String getJSONUrl(String url,List<NameValuePair> params) {
StringBuilder str = new StringBuilder();
HttpClient client = new DefaultHttpClient();
HttpPost httpPost = new HttpPost(url);
try {
httpPost.setEntity(new UrlEncodedFormEntity(params,"UTF-8"));
HttpResponse response = client.execute(httpPost);
StatusLine statusLine = response.getStatusLine();
int statusCode = statusLine.getStatusCode();
if (statusCode == 200) { // Download OK
HttpEntity entity = response.getEntity();
InputStream content = entity.getContent();
BufferedReader reader = new BufferedReader(new InputStreamReader(content));
String line;
while ((line = reader.readLine()) != null) {
str.append(line);
}
} else {
Log.e("Log", "Failed to download file..");
}
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return str.toString();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
}
ผมจะต้องเพิ่มตรงไหนเพื่อรับค่าอีกค่าหรอครับ
รบกวนด้วยนะครับ
ประวัติการแก้ไข 2015-04-05 16:56:05
Date :
2015-04-05 16:54:56
By :
dewzaa186
เรื่อง Android นี่ผมโง่ ขึ้นหน้าเลยครับ .. ความรู้ผมไม่มีจริง ๆ ครับ
พอจะช่วยได้ ก็แต่เรื่อง PHP น่ะครับ
ประวัติการแก้ไข 2015-04-05 17:06:21
Date :
2015-04-05 17:05:53
By :
deawx
แค่พี่ช่วยผมเรื่อง PHP ก็เป็นพระคุณแล้วครับ
ผมสิ จะสอบอยู่แล้วยังงูๆ ปลาๆ อยู่เลย
Date :
2015-04-05 17:15:17
By :
dewzaa186
Load balance : Server 01