Я пытаюсь отфильтровать данные из таблицы SQL.Это в моем запросе.
SELECT TOP 10 ItemCode, ItemName
FROM [mytable]
WHERE ItemCode like '".$q."%' order by CreatedDate desc
вот мой залп
private void getItem(String s){
JsonArrayRequest postRequest = new JsonArrayRequest (Request.Method.GET, "http://192.168.3.9/api/welcome/getItem/"+s,null,
new Response.Listener<JSONArray>()
{
@Override
public void onResponse(JSONArray response) {
try {
if (itemList == null) itemList = new ArrayList<>();
itemList.clear();
for(int i = 0; i < response.length(); i++){
Item_model m_item = new Item_model();
List<String> list = new ArrayList<String>();
m_item.setItemCode(response.getJSONObject(i).getString("ItemCode"));
itemList.add(m_item);
}
itemcode.setAdapter(adapter);
adapter.notifyDataSetChanged();
} catch (JSONException e) {
e.printStackTrace();
}
}
},
new Response.ErrorListener()
{
@Override
public void onErrorResponse(VolleyError error) {
Log.d("ErrorResponse", error.toString());
}
}
);
postRequest.setRetryPolicy(new DefaultRetryPolicy(0, DefaultRetryPolicy.DEFAULT_MAX_RETRIES, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
postRequest.setTag("GetItem");
queue.add(postRequest);
}
я вызываю getItem внутри onCreateView
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
getItem("");
}
сейчас мой код работаетхорошо, потому что я хочу фильтровать, поэтому я использую TextWatcher
, вот что я делаю.
itemcode.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
search = s.toString();
getItem("");
adapter.getFilter().filter(search);
}
});
когда я реализую свой скрипт выше, мое представление автозаполнения текста не показывает никаких данных, как я могу это исправить?
Мой JSON
[{"ItemCode":"IT001","ItemName":"Blue Hat"},{"ItemCode":"IT002","ItemName":"Black Hat"}]