私はアンドロイド開発の初心者です。sqllite テーブル (id、name、number) に詳細を追加しています。今、私はそれをリストしようとしています。名前だけをリストしたいだけです。特定の名前をクリックすると、特定の名前の番号が表示されます。今、私は名前をリストしようとしています。私のコードは.
details.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" >
<ListView
android:cacheColorHint="#00000000"
android:layout_height="wrap_content"
android:layout_width="fill_parent"
android:id="@android:id/list"
android:layout_alignParentLeft="true">
</ListView>
</LinearLayout>
詳細操作.java
public class DetailOperations {
private DataBase dbHelper;
private String[] DETAILS_TABLE_COLUMNS = { DataBase.DETAIL_ID, DataBase.DETAIL_NAME,DataBase.DETAIL_NO };
private SQLiteDatabase database;
public DetailOperations(Context context) {
dbHelper = new DataBase(context);
}
public void open() throws SQLException {
database = dbHelper.getWritableDatabase();
}
public void close() {
dbHelper.close();
}
public List getAllDetails(){
List Details=new ArrayList();
Cursor cursor = database.query(DataBase.DETAILS,
DETAILS_TABLE_COLUMNS, null, null, null, null, null);
cursor.moveToFirst();
while(!cursor.isAfterLast()){
Detail de=parseDetail(cursor);
Details.add(de);
cursor.moveToNext();
}
cursor.close();
return Details;
}
private Detail parseDetail(Cursor cursor) {
Detail d = new Detail();
d.setId((cursor.getInt(0)));
d.setName(cursor.getString(1));
d.setnumber(cursor.getString(2));
return d;
}
}
詳細.java
public class Details extends ListActivity {
private DetailOperations detailDBoperation;
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.details);
detailDBoperation=new DetailOperations(this);
detailDBoperation.open();
List<Detail> values=detailDBoperation.getAllDetails();
List<String> names=new ArrayList<String>();
for(int i=0;i<values.size();i++)
{
names.add(values.get(i).getName());
}
ArrayAdapter adapter=new ArrayAdapter(this,android.R.layout.simple_list_item_1,names);
// List values=detailDBoperation.getAllDetails();
// ArrayAdapter adapter=new ArrayAdapter(this,android.R.layout.simple_list_item_1,list ofDetail ->Name);
setListAdapter(adapter);
setListAdapter(adapter);
}
@Override
protected void onResume(){
detailDBoperation.open();
super.onResume();
}
@Override
protected void onPause(){
detailDBoperation.close();
super.onPause();
}
}
詳細.java
public class Detail {
private int id;
private String name;
private String number;
public long getId() { return id;}
public void setId(int id) { this.id = id; }
public String getName() { return this.name; }
public void setName(String name) { this.name = name; }
public String getNumber(){ return this.number; }
public void setnumber(String number){ this.number=number; }
}
しかし、私はそのような出力リストを得ました
com.example.experiments.Detail@417c38d0
com.example.experiments.Detail@417c3a10
com.example.experiments.Detail@417c3ab0