在 Android 异常中插入 SQLite

Insert into SQLite in Android Exception

我创建了一个简单的 Android 应用程序来处理 SQLite 数据库以从 table 插入和检索数据,但是当我尝试插入数据或检索时出现如下所示的异常:

01-26 15:48:30.930: E/AndroidRuntime(25783): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.androidhive.loginandregister/com.androidhive.loginandregister.LoginActivity}: android.database.sqlite.SQLiteException: near ")": syntax error (code 1): , while compiling: INSERT INTO info() VALUES (?)

下面是我的代码:

LoginActivity.java

package com.androidhive.loginandregister;

import android.app.Activity;
import android.database.Cursor;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

public class LoginActivity extends Activity {
    DataHandler data;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.login);

        data= new DataHandler(getBaseContext());
        data.open();
        long x = data.insertdata("a", "b", "c", "d", "e");

        Toast.makeText(getBaseContext(),"Insertion Completed", Toast.LENGTH_LONG).show();

        data.close();

        Button btn = (Button)findViewById(R.id.btnLogin);

        btn.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {

                data = new DataHandler(getBaseContext());
                data.open();
                Cursor c = data.returndata();
                if(c.moveToFirst())
                {
                    do
                    {
                        Toast.makeText(getBaseContext(),c.getString(0)+ " "+ c.getString(1)+" "+c.getString(2) ,Toast.LENGTH_LONG).show();
                    }while(c.moveToNext());


                    }
                data.close();
                }

                });

    }
}

DataHandler.java

package com.androidhive.loginandregister;

import android.content.ContentValues;
import android.content.Context;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class DataHandler {

    public static final String id ="";
    public static final String name ="";
    public static final String number ="";
    public static final String email ="";
    public static final String website ="";
    public static final String table_name ="info";
    public static final String data_base_name ="bcb";
    public static final int database_version = 1;
    public static final String table_create ="CREATE TABLE info(id TEXT,name TEXT,number TEXT,email TEXT,website TEXT);";

    databasehelper dbhelper;
    Context ctx;
    SQLiteDatabase db;


    public DataHandler (Context ctx)
    {
        this.ctx=ctx;
        dbhelper = new databasehelper(ctx);
    }

    private static class databasehelper extends SQLiteOpenHelper
    {

    public databasehelper(Context ctx)
    {
        super(ctx,data_base_name,null,database_version);
    }

        @Override
        public void onCreate(SQLiteDatabase db) {

            try
            {
                db.execSQL(table_create);
            }

            catch (SQLException e)
            {
                e.printStackTrace();
            }

        }




        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

            db.execSQL("DROP TABLE IF EXISTS info");
            onCreate(db);
        }

    }


    public DataHandler open()
    {
    db = dbhelper.getWritableDatabase();
    return this;
    }

    public void close()
    {
        dbhelper.close();

    }

    public long insertdata(String ID, String NAME,String NUMBER,String EMAIL,String WEBSITE,String COMPANY,String PROFESSION,String COMMENTS,String STATUS)
    {
        ContentValues content = new ContentValues();
        content.put(id, ID);
        content.put(name, NAME);
        content.put(number,NUMBER);
        content.put(email, EMAIL);
        content.put(website, WEBSITE);
        return db.insertOrThrow(table_name, null, content);


    }

    public Cursor returndata()
    {
        return db.query(table_name, new String [] {id,name,number,email,website}, null, null, null, null, null);
    }
}

感谢您的帮助。

我假设这些应该包含您的列名

public static final String id ="";
public static final String name ="";
public static final String number ="";
public static final String email ="";
public static final String website ="";

这就是您在插入查询中得到空列列表的原因。用适当的值填充它们。