0

我的功能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 在两个日期之间获取数据,我想将获取的数据显示到列表视图中,请帮助我如何做到这一点我是 android 开发的新手。

4

4 回答 4

1

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

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

于 2013-04-01T13:34:40.997 回答
0

你可以按照这个例子:

DataManipulator.java -helper 类

 //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]);
}


}

点击此链接获取完整教程

于 2013-04-01T13:37:31.117 回答
0

我假设您正在从数据库中获取数据,并通过带有 Airline 对象的完整 ArrayList 获取数据。

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

给你:如何为 ListView 定义自定义适配器?

于 2013-04-01T13:34:21.510 回答
0

我想将获取的数据显示到列表视图中请帮助我如何做到这一点我是 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()您的 Airline 类中的方法。

原因是您ArrayAdapter会将每个子项(提供的航空公司列表)转换为字符串,如果您不覆盖 toString(),您将获得对象的默认字符串表示,但您可能需要显示航空公司的实例名称,以便您的方法看起来喜欢

@Override
public String toString() {
   return this.name;
}

笔记:

这是简单的方法。但是,如果您想更好地控制 ListView 并创建自定义列表,我建议您创建自己的 ListAdapter 子类,例如 BaseAdapter 并定义自己的适配器。抱歉,我不会为您编写实现,因为它需要更多代码,但您可以在此处找到很好的示例:

于 2013-04-01T13:36:12.013 回答