Ошибка при вставке элементов в базу данных sqlite - PullRequest
0 голосов
/ 19 января 2012

Когда я впервые создаю свою базу данных, я вставляю в нее некоторые элементы, но при этом все время получаю сообщение об ошибке, и я не знаю, почему

01-19 11:23:56.850: E/SQLiteDatabase(11243): Error inserting manufacturer_id=0 ball=Train name=900 Global
01-19 11:23:56.850: E/SQLiteDatabase(11243): android.database.sqlite.SQLiteException: unrecognized token: ":": , while compiling: INSERT INTO content://com.tyczj.bowling.providers.balls/balls(manufacturer_id,ball,name) VALUES (?,?,?)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteCompiledSql.native_compile(Native Method)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteCompiledSql.<init>(SQLiteCompiledSql.java:64)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteProgram.compileSql(SQLiteProgram.java:146)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteProgram.compileAndbindAllArgs(SQLiteProgram.java:367)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteStatement.acquireAndLock(SQLiteStatement.java:253)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteStatement.executeInsert(SQLiteStatement.java:111)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1737)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteDatabase.insert(SQLiteDatabase.java:1610)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at com.tyczj.bowling.providers.Manufacturers$DatabaseHelper.onCreate(Manufacturers.java:65)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:157)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at com.tyczj.bowling.providers.Manufacturers.onCreate(Manufacturers.java:226)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.content.ContentProvider.attachInfo(ContentProvider.java:955)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.app.ActivityThread.installProvider(ActivityThread.java:3981)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.app.ActivityThread.installContentProviders(ActivityThread.java:3736)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at and roid.app.ActivityThread.handleBindApplication(ActivityThread.java:3692)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.app.ActivityThread.access$1200(ActivityThread.java:122)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1065)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.os.Handler.dispatchMessage(Handler.java:99)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.os.Looper.loop(Looper.java:132)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at android.app.ActivityThread.main(ActivityThread.java:4126)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at java.lang.reflect.Method.invokeNative(Native Method)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at java.lang.reflect.Method.invoke(Method.java:491)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:844)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)
01-19 11:23:56.850: E/SQLiteDatabase(11243):    at dalvik.system.NativeStart.main(Native Method)

в своей базе данных при создании я получаю строковый массив (список производителей) из ресурсов и, основываясь на производителе, вставляю элементы другого элемента в другую базу данных. происходит сбой при вставке элементов на основе производителя

это моя база данных производителей, где все происходит

@Override
    public void onCreate(SQLiteDatabase db) 
    {
        createTables(db);
        String[] manufacturers = context.getResources().getStringArray(R.array.manufacturers);
        ContentValues v = new ContentValues();
        for(int i = 0; i < manufacturers.length; i++){
            Log.d("Manufacturers",manufacturers[i]);
            v.put(NAME,manufacturers[i]);
            db.insert(MANUFACTURERS_TABLE,null,v);
            String[] balls;
            if(i == 0){
                balls = context.getResources().getStringArray(R.array.global);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 1){
                balls = context.getResources().getStringArray(R.array.amf);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }

            }else if(i == 2){
                balls = context.getResources().getStringArray(R.array.brunswick);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 3){
                balls = context.getResources().getStringArray(R.array.columbia);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 4){
                balls = context.getResources().getStringArray(R.array.ebonite);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 5){
                balls = context.getResources().getStringArray(R.array.hammer);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 6){
                balls = context.getResources().getStringArray(R.array.morich);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 7){
                balls = context.getResources().getStringArray(R.array.rotogrip);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 8){
                balls = context.getResources().getStringArray(R.array.storm);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 9){
                balls = context.getResources().getStringArray(R.array.track);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 10){
                balls = context.getResources().getStringArray(R.array.motiv);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 11){
                balls = context.getResources().getStringArray(R.array.elite);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }else if(i == 12){
                balls = context.getResources().getStringArray(R.array.dv8);
                for(int j = 0; j<balls.length;j++){
                    Log.d("Manufacturers",balls[j]);
                    v.put(Balls.MANUFACTURER_ID,i);
                    v.put(Balls.BALL,balls[j]);
                    db.insert(Balls.CONTENT_URI.toString(),null,v);
                }
            }
        }

    }

это моя вставка во вторую базу данных

@Override
public Uri insert(Uri uri, ContentValues values) {
    long rowID = db.insert(BALLS_TABLE,null, values);
    if(rowID > 0){
        Uri _uri = ContentUris.withAppendedId(CONTENT_ID_URI_BASE,rowID);
        getContext().getContentResolver().notifyChange(_uri,null);
        return _uri;
    }else{
        throw new SQLException("Failed to insert row into " + uri);
    }
}

теперь я не вижу нигде в моей вставке, где есть :, что говорит о проблеме, поэтому я не знаю, что не так. Могу ли я так не вставить?

EDIT:

мой другой стол

private static final String DATABASE_NAME = "Balls";
private static final String BALLS_TABLE = "balls";
private static final int DATABASE_VERSION = 1;
private static final String  AUTHORITY = "com.tyczj.bowling.providers.balls";
public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/balls");
public static final Uri CONTENT_ID_URI_BASE = Uri.parse("content://" + AUTHORITY + "/balls/");
private static final UriMatcher uriMatcher;
public static final String BALL = "ball";
public static final String ID = "_id";
public static final String MANUFACTURER_ID = "manufacturer_id";

private static final HashMap<String, String> mMap;
private DatabaseHelper DBHelper;
private SQLiteDatabase db;

и мой создатель этого стола

    @Override
public boolean onCreate() {
    Context context = getContext();
    DBHelper = new DatabaseHelper(context);
    db = DBHelper.getWritableDatabase();
    return (db == null)? false:true;
}

РЕДАКТИРОВАТЬ 2:

Таблица производителей

private void createTables(SQLiteDatabase db){
        db.execSQL("CREATE TABLE " + MANUFACTURERS_TABLE + "(" + ID + " integer primary key autoincrement, " +
                NAME + " TEXT);");
    }

стол с шариками

private void createTables(SQLiteDatabase db){
        db.execSQL("CREATE TABLE " + BALLS_TABLE + "(" + ID + " integer primary key autoincrement, " +
                 MANUFACTURER_ID + " INTEGER, " + BALL + " TEXT);");
    }

Ответы [ 3 ]

0 голосов
/ 19 января 2012

Должна быть некоторая проблема в определении вашей таблицы.
Проверьте, правильно ли вы определили столбцы.
Также, если вы можете опубликовать этот код здесь, будет полезно для отладки.

0 голосов
/ 19 января 2012

Вам необходимо вызвать db.insert, передав непосредственно имя таблицы, а не содержимое uri

попробовать

        if(i == 0){
            balls = context.getResources().getStringArray(R.array.global);
            for(int j = 0; j<balls.length;j++){
                Log.d("Manufacturers",balls[j]);
                v.put(Balls.MANUFACTURER_ID,i);
                v.put(Balls.BALL,balls[j]);
                db.insert("balls",null,v);
            }
        }
0 голосов
/ 19 января 2012

Хорошо, я вижу знак ":" здесь:

content: //com.tyczj.bowling.providers.balls/balls (factory_id, ball, name)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...