Здравствуйте! Помогите реализовать поиск по двум параметрам и двум полям.
Осуществлен обычный поиск в базе по полям с одним параметром (одно поисковое поле).
PHP код:
import android.annotation.TargetApi;
import android.app.Activity;
import android.os.Build;
import android.os.Bundle;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.Editable;
import android.text.TextWatcher;
import android.widget.EditText;
import android.widget.FilterQueryProvider;
import android.widget.ListView;
import android.database.Cursor;
import android.widget.SimpleCursorAdapter;
import java.sql.SQLException;
public class tram_ extends AppCompatActivity {
ListView userList;
EditText userFilter;
DatabaseHelper sqlHelper;
Cursor userCursor;
SimpleCursorAdapter userAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.tram);
userList = (ListView)findViewById(R.id.userList);
userFilter = (EditText)findViewById(R.id.userFilter);
sqlHelper = new DatabaseHelper(getApplicationContext());
sqlHelper.create_db();
}
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
@Override
public void onResume(){
super.onResume();
try {
sqlHelper.open();
userCursor = sqlHelper.database.rawQuery("select * from " + DatabaseHelper.TABLE, null);
String[] headers = new String[]{DatabaseHelper.COLUMN_MAR, DatabaseHelper.COLUMN_OST, DatabaseHelper.COLUMN_TIME,DatabaseHelper.COLUMN_NAPR};
userAdapter = new SimpleCursorAdapter(this, R.layout.my_,
userCursor, headers, new int[]{R.id.textmar, R.id.textost, R.id.texttime, R.id.textnapr}, 0);
if(!userFilter.getText().toString().isEmpty())
userAdapter.getFilter().filter(userFilter.getText().toString());
userFilter.addTextChangedListener(new TextWatcher() {
public void afterTextChanged(Editable s) {
}
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
public void onTextChanged(CharSequence s, int start, int before, int count) {
userAdapter.getFilter().filter(s.toString());
}
});
userAdapter.setFilterQueryProvider(new FilterQueryProvider() {
@Override
public Cursor runQuery(CharSequence constraint) {
if (constraint == null || constraint.length() == 0) {
return sqlHelper.database.rawQuery("select * from " + DatabaseHelper.TABLE, null);
}
else {
return sqlHelper.database.rawQuery("select * from " + DatabaseHelper.TABLE +
" where " + DatabaseHelper.COLUMN_MAR + " like ?" + " or " + " "
+ DatabaseHelper.COLUMN_OST + " like ?",
new String[]{"%" + constraint.toString() + "%", "%" + constraint.toString() + "%"});
}
}
});
userList.setAdapter(userAdapter);
}
catch (SQLException ex){}
}
@Override
public void onDestroy(){
super.onDestroy();
// Закрываем подключения
sqlHelper.database.close();
userCursor.close();
}
}
и
Сам xml
PHP код:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" android:orientation="vertical"
android:focusable="true"
android:focusableInTouchMode="true"
android:weightSum="1">
<EditText android:id="@+id/userFilter" android:layout_width="match_parent"
android:layout_height="wrap_content" android:ems="10"
android:hint="Введите первый параметр"
/>
<EditText
android:id="@+id/editText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ems="10"
android:hint="Введите второй параметр" />
<ListView
android:id="@+id/userList"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:focusable="true"
android:focusableInTouchMode="true">
</ListView>
</LinearLayout>
Поиск сейчас осуществляется через поле @+id/userFilter в двух полях базы, это text_mar и text_ost, Что бы было понятнее, мне нужен поиск одновременный т. е. расширенный
@+id/userFilter в поле text_mar
а, допустим
@+id/editText в поле text_ost
Можно ли такое вообще реализовать