我在我的main.xml文件中添加了EditText,Button和ListView。用戶將輸入全名或一些字母的名稱,並點擊按鈕。按鈕點擊事件將顯示聯繫人列表中與用戶查詢對應的所有姓名和電話號碼。內容提供者拋出異常
這是我的onClick功能代碼:
Uri lookupUri = Uri.withAppendedPath(ContactsContract.Contacts.CONTENT_FILTER_URI, editText.getText().toString());
Cursor idCursor = getContentResolver().query(lookupUri, null, null, null, null);
startManagingCursor(idCursor);
String wherestmt = ContactsContract.Data.CONTACT_ID + " = " + idCursor + " And " + ContactsContract.Data.MIMETYPE + " = " + ContactsContract.CommonDataKinds.Phone.CONTENT_URI + "'";
Cursor datacursor = getContentResolver().query(ContactsContract.Data.CONTENT_URI,null,wherestmt,null,null);
int nameIdx = datacursor.getColumnIndexOrThrow(ContactsContract.Data.DISPLAY_NAME);
int phoneIdx = datacursor.getColumnIndexOrThrow(ContactsContract.CommonDataKinds.Phone.NUMBER);
datacursor.moveToFirst();
list = new ArrayList<String>();
do{
String name = datacursor.getString(nameIdx);
String phone = datacursor.getString(phoneIdx);
list.add(name + " " + phone);
}while(datacursor.moveToNext());
ListAdapter adapter = new ArrayAdapter<String>(this, android.R.layout.simple_expandable_list_item_1,list);
listView.setAdapter(adapter);
但是,我得到一個例外,在以下行:
Cursor datacursor = getContentResolver().query(ContactsContract.Data.CONTENT_URI,null,wherestmt,null,null);
例外講述這樣的:
android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:135)
FATAL EXCEPTION: main E/AndroidRuntime(1287): android.database.sqlite.SQLiteException: near "@412c63d0": syntax error: ,[email protected] And mimetype = 'content://com.android.contacts/data/phones')) 04-01 13:48:46.616: E/AndroidRuntime(1287): at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:179) 04-01 13:48:46.616: E/AndroidRuntime(1287): at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:135)
任何幫助??????? – WhoAmI 2012-04-01 16:21:33