android调试错误列'data3'不存在

Posted

技术标签:

【中文标题】android调试错误列\'data3\'不存在【英文标题】:android debug error column 'data3' does not existandroid调试错误列'data3'不存在 【发布时间】:2011-07-21 22:51:51 【问题描述】:

java.lang.IllegalArgumentException:列“data3”不存在 data3 列是什么?

LogCat

03-24 07:05:36.091: 错误/androidRuntime(2540):致命 例外:主要

03-24 07:05:36.091: 错误/AndroidRuntime(2540): java.lang.RuntimeException:无法 开始活动 组件信息fypj.e/fypj.e.e: java.lang.IllegalArgumentException: 列“data3”不存在

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.app.ActivityThread.access$2300(ActivityThread.java:125)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.os.Handler.dispatchMessage(Handler.java:99)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.os.Looper.loop(Looper.java:123)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.app.ActivityThread.main(ActivityThread.java:4627)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 java.lang.reflect.Method.invokeNative(Native 方法)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 java.lang.reflect.Method.invoke(Method.java:521)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 dalvik.system.NativeStart.main(Native 方法)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):由以下原因引起: java.lang.IllegalArgumentException: 列“data3”不存在

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:314)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.database.CursorWrapper.getColumnIndexOrThrow(CursorWrapper.java:99)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.widget.SimpleCursorAdapter.findColumns(SimpleCursorAdapter.java:312)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.widget.SimpleCursorAdapter.(SimpleCursorAdapter.java:87)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 fypj.e.e.onCreate(e.java:48)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)

03-24 07:05:36.091: 错误/AndroidRuntime(2540):在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)

03-24 07:05:36.091: 错误/AndroidRuntime(2540): ... 11 更多

package fypj.e;

import android.app.ListActivity; 
import android.content.ContentUris;
import android.content.ContentValues;
import android.database.Cursor; 
import android.net.Uri;
import android.os.Bundle; 
import android.provider.Contacts.People; 
import android.provider.ContactsContract;
import android.provider.ContactsContract.CommonDataKinds.Phone; 
import android.provider.ContactsContract.CommonDataKinds.StructuredName;
import android.provider.ContactsContract.Data;
import android.provider.ContactsContract.RawContacts;
import android.widget.*;  

public class e extends ListActivity  
    private SimpleCursorAdapter myAdapter;     @Override
    public void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        ContentValues values = new ContentValues(); 
        values.put(RawContacts.ACCOUNT_TYPE, ""); 
        values.put(RawContacts.ACCOUNT_NAME, ""); 
        Uri rawContactUri = 
getContentResolver().insert(RawContacts.CONTENT_URI, values); 
        long rawContactId = ContentUris.parseId(rawContactUri); 


        values.clear(); 
        values.put(Data.RAW_CONTACT_ID, rawContactId); 
        values.put(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE); 
        values.put(StructuredName.DISPLAY_NAME, "Misha"); 
        values.put(Phone.LABEL, "Mis");
        values.put(ContactsContract.Data.DATA3, "View Contact");
        getContentResolver().insert(Data.CONTENT_URI, values); 


        //contentResolver = getContentResolver(); 



        Cursor cursor = getContentResolver().query(People.CONTENT_URI, null, null, null, null);         
        startManagingCursor(cursor);          
        String[] column = new String[] Phone.LABEL;         
        int[] names = new int[] R.id.contact_name;         
        myAdapter = new SimpleCursorAdapter(this, R.layout.main, cursor, column, names);         
        setListAdapter(myAdapter);     
     

【问题讨论】:

在我看来很明显,回答这个问题需要更多信息。为什么不添加一些代码?努力吧。 我几乎不怀疑任何人都可以回答这样的问题。给我们更多信息。您要做什么,抛出异常的一些示例代码。 【参考方案1】:

我不知道您使用的是哪个 sdk,但在 2.2 中,大多数数据包都已弃用。但是问题是具有常量值“data3”的Phone.Label列不存在于游标返回的列中。

【讨论】:

我使用的是 2.2。包被贬值是什么意思?我该如何解决呢? 例如developer.android.com/reference/android/provider/…Constacts.People 已被弃用,例如不再受支持,您应该避免使用它。查看文档中哪些是受支持的列,看看您可以选择哪一个。【参考方案2】:

只能猜测,但也许您正在使用“data3”作为某个执行数据库工作的函数的参数,而“data3”在您的数据库中不存在?

【讨论】:

我不确定。我该如何检查或解决这个问题??

以上是关于android调试错误列'data3'不存在的主要内容,如果未能解决你的问题,请参考以下文章

Android Studio APK 安装错误:“本地路径不存在”

如果存在多索引,熊猫将不允许选择列?

Spring源码报错:错误: 程序包jdk.jfr不存在

android: ADB错误“more than one device and emulator”

Android列'_id'不存在?

选择SQL中两列之间的关系