如何将从数据库表中获取的数据显示到listview中?

时间:2013-04-01 13:21:52

标签: java android

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开发的新手。

4 个答案:

答案 0 :(得分:1)

您可以使用SimpleCursorAdapter在Listview中显示数据库内容。创建SimpleCursorAdapter的实例并将Cursor对象传递给它。 Refer此链接

如果您想要自定义列表视图,可以通过使用自定义适配器类扩展它来自定义SimpleCursorAdapter。

答案 1 :(得分:0)

我假设您从数据库获取数据,并通过完整的ArrayList和Airline对象获取数据。

现在要从ArrayList<Airline>在ListView中显示数据,您必须通过扩展BaseAdapterArrayAdapter来定义自定义适配器类

在这里:How to define custom adapter for ListView?

答案 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获取完整教程