SQLAdapter class
中的我的功能
public ArrayList<Airline> getairlinedetails(String bookingdate) {
Cursor curCalllog =db.rawQuery("SELECT * FROM "+ BOOK +
" WHERE " + date +
" BETWEEN '" + startdate + "' AND '" + enddate + "'", null);
if (curCalllog != null) {
if (curCalllog.moveToFirst()) {
do {
a=new Airline();
//a.setBookingdate(curCalllog.getString(1));
a.setPickupadd(curCalllog.getString(2));
a.setCity(curCalllog.getString(3));
a.setTrip(curCalllog.getString(4));
a.setFdate(curCalllog.getString(5));
a.setFtime(curCalllog.getString(6));
a.setCdate(curCalllog.getString(7));
a.setPtime(curCalllog.getString(8));
a.setSeats(curCalllog.getInt(9));
a.setAmount(curCalllog.getInt(10));
update.add(a);
} while (curCalllog.moveToNext());
}
}
return update;
}
M在两个日期和之间获取数据 我想将获取的数据显示到listview中,请帮助我如何做到这一点我是android开发的新手。
答案 0 :(得分:1)
您可以使用SimpleCursorAdapter在Listview中显示数据库内容。创建SimpleCursorAdapter的实例并将Cursor对象传递给它。 Refer此链接
如果您想要自定义列表视图,可以通过使用自定义适配器类扩展它来自定义SimpleCursorAdapter。
答案 1 :(得分:0)
我假设您从数据库获取数据,并通过完整的ArrayList和Airline对象获取数据。
现在要从ArrayList<Airline>
在ListView中显示数据,您必须通过扩展BaseAdapter
或ArrayAdapter
来定义自定义适配器类。
答案 2 :(得分:0)
我想将获取的数据显示到listview中请帮我怎么做 它是我在Android开发中的新手
最简单的方法是将ArrayAdapter
与内置ListView's
行布局一起使用。
ListView list = (ListView) findViewById(R.id.yourList);
ArrayList<Airline> data = db.getairlinedetails("someString");
ArrayAdapter<Airline> adapter = new ArrayAdapter<Airline>(this,
android.R.layout.simple_list_item_1, data);
list.setAdapter(adapter);
但是,因为你需要在你的航空公司课程中覆盖toString()
方法。
原因是您的ArrayAdapter
会将每个孩子(提供的航空公司列表)转换为String,如果您不会覆盖toString(),您将获得对象的默认字符串表示形式您可能需要显示航空公司的实例名称,以便您的方法看起来像
@Override
public String toString() {
return this.name;
}
这是一种简单的方法。但是如果你想要更多地控制ListView并创建自定义列表,我建议你创建自己的ListAdapter子类,例如BaseAdapter,并定义你自己的适配器。抱歉,我不会写你的实现,因为它需要更多的代码,但你可以在这里找到很好的例子:
答案 3 :(得分:0)
你可以按照这个例子:
DataManipulator.java -helper class
//to retrieve data in a list
public List<String[]> selectAll()
{
List<String[]> list = new ArrayList<String[]>();
Cursor cursor = db.query(TABLE_NAME, new String[] { "id","name","number","skypeId","address" },
null, null, null, null, "name asc");
int x=0;
if (cursor.moveToFirst()) {
do {
String[] b1=new String[]{cursor.getString(0),cursor.getString(1),cursor.getString(2),cursor.getString(3),cursor.getString(4)};
list.add(b1);
x=x+1;
} while (cursor.moveToNext());
}
if (cursor != null && !cursor.isClosed()) {
cursor.close();
}
cursor.close();
return list;
}
<强> CheckData.java 强> //在列表视图中显示数据
public class CheckData extends ListActivity {
TextView selection;
public int idToModify;
DataManipulator dm;
List<String[]> list = new ArrayList<String[]>();
List<String[]> names2 =null ;
String[] stg1;
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.check);
dm = new DataManipulator(this);
names2 = dm.selectAll();
stg1=new String[names2.size()];
int x=0;
String stg;
for (String[] name : names2) {
stg = name[1]+" - "+name[2]+ " - "+name[3]+" - "+name[4];
stg1[x]=stg;
x++;
}
ArrayAdapter<String> adapter = new ArrayAdapter<String>(
this,android.R.layout.simple_list_item_1,
stg1);
this.setListAdapter(adapter);
selection=(TextView)findViewById(R.id.selection);
}
public void onListItemClick(ListView parent, View v, int position, long id) {
selection.setText(stg1[position]);
}
}
按照此link获取完整教程