Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/windows/17.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 内容提供程序错误:绑定或列索引超出范围:句柄0x234590_Android_Android Contentprovider - Fatal编程技术网

Android 内容提供程序错误:绑定或列索引超出范围:句柄0x234590

Android 内容提供程序错误:绑定或列索引超出范围:句柄0x234590,android,android-contentprovider,Android,Android Contentprovider,我已经实现了一个内容提供者,它导致了以下错误 04-25 00:25:16.856:E/AndroidRuntime(520):由以下原因引起:android.database.sqlite.SQLiteException:绑定或列索引超出范围:句柄0x234590 内容提供程序中的查询为 Cursor cursor = qb.query(db, projection, selection, selectionArgs, null, null, sortOrder);

我已经实现了一个内容提供者,它导致了以下错误

04-25 00:25:16.856:E/AndroidRuntime(520):由以下原因引起:android.database.sqlite.SQLiteException:绑定或列索引超出范围:句柄0x234590

内容提供程序中的查询为

Cursor cursor = qb.query(db, projection, selection, selectionArgs, null, null,
            sortOrder);
cursor = cr.query(uri, new String[] { ContactTableMetaData.ABC,
            ContactTableMetaData.MNP }, ContactTableMetaData.XYZ + "=?",
            new String[] { "phonenumber1", "phonenumber2", "phonenumber3",
                    "phonenumber4", "phonenumber5", "email1", "email2", "email3",
                    "email4", "email5" }, null);
对内容提供商的呼叫是

Cursor cursor = qb.query(db, projection, selection, selectionArgs, null, null,
            sortOrder);
cursor = cr.query(uri, new String[] { ContactTableMetaData.ABC,
            ContactTableMetaData.MNP }, ContactTableMetaData.XYZ + "=?",
            new String[] { "phonenumber1", "phonenumber2", "phonenumber3",
                    "phonenumber4", "phonenumber5", "email1", "email2", "email3",
                    "email4", "email5" }, null);
完整的日志是

04-25 00:25:16.856: E/AndroidRuntime(520): FATAL EXCEPTION: main
04-25 00:25:16.856: E/AndroidRuntime(520): java.lang.RuntimeException: Unable to start activity     04-25 00:25:16.856: E/AndroidRuntime(520):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.app.ActivityThread.access$2300(ActivityThread.java:125)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.os.Handler.dispatchMessage(Handler.java:99)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.os.Looper.loop(Looper.java:123)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.app.ActivityThread.main(ActivityThread.java:4627)
04-25 00:25:16.856: E/AndroidRuntime(520):  at java.lang.reflect.Method.invokeNative(Native Method)
04-25 00:25:16.856: E/AndroidRuntime(520):  at java.lang.reflect.Method.invoke(Method.java:521)
04-25 00:25:16.856: E/AndroidRuntime(520):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
04-25 00:25:16.856: E/AndroidRuntime(520):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
04-25 00:25:16.856: E/AndroidRuntime(520):  at dalvik.system.NativeStart.main(Native Method)
04-25 00:25:16.856: E/AndroidRuntime(520): Caused by: android.database.sqlite.SQLiteException: bind or column index out of range: handle 0x234590
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.database.sqlite.SQLiteProgram.native_bind_string(Native Method)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.database.sqlite.SQLiteProgram.bindString(SQLiteProgram.java:241)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.database.sqlite.SQLiteQuery.bindString(SQLiteQuery.java:182)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:48)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1345)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.database.sqlite.SQLiteQueryBuilder.query(SQLiteQueryBuilder.java:330)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.database.sqlite.SQLiteQueryBuilder.query(SQLiteQueryBuilder.java:280)
04-25 00:25:16.856: E/AndroidRuntime(520):  at com.wissenways.helper.VoiceAppContactContentProvider.query(VoiceAppContactContentProvider.java:171)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.content.ContentProvider$Transport.query(ContentProvider.java:163)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.content.ContentResolver.query(ContentResolver.java:245)
04-25 00:25:16.856: E/AndroidRuntime(520):  at com.wissenways.checkcontacts.DisplayGreatPeople.onCreate(DisplayGreatPeople.java:45)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
04-25 00:25:16.856: E/AndroidRuntime(520):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
04-25 00:25:16.856: E/AndroidRuntime(520):  ... 11 more
谢谢

String selection = ContactTableMetaData.XYZ + "=?";
String[] selectionArgs = new String[] { "phonenumber1", "phonenumber2", "phonenumber3",
                    "phonenumber4", "phonenumber5", "email1", "email2", "email3",
                    "email4", "email5" }
的数量必须与
selectionArgs
的数量相匹配。如果您提供10个项目,则
选择必须有10个

选择
中的第N个
项替换为
selectionArgs
中的第N个项

编辑:如果要检查ContactTableMetaData.XYZ是否为其中任何一个,请选择

String selection = ContactTableMetaData.XYZ + "=? OR " + ContactTableMetaData.XYZ + "=? OR " + ...

我更喜欢第二个:)

的数量必须与
selectionArgs
的数量相匹配。如果您提供10个项目,则
选择必须有10个

选择
中的第N个
项替换为
selectionArgs
中的第N个项

编辑:如果要检查ContactTableMetaData.XYZ是否为其中任何一个,请选择

String selection = ContactTableMetaData.XYZ + "=? OR " + ContactTableMetaData.XYZ + "=? OR " + ...

我更喜欢第二个:)

公共静态字符串getWhereStr(字符串columnName,int-selectionArgsSize){
字符串delim=“,”;
最终StringBuilder buf=新StringBuilder();
buf.在(“)中追加(columnName+”;
对于(int i=0;i
公共静态字符串getWhereStr(字符串列名,int-selectionArgsSize){
字符串delim=“,”;
最终StringBuilder buf=新StringBuilder();
buf.在(“)中追加(columnName+”;
对于(int i=0;i
谢谢。我想检查所有10个值的选择值。怎么做?谢谢。我想检查所有10个值的选择值。怎么做?