将数据插入sqlite数据库时出错

时间:2016-06-20 20:17:15

标签: java android sqlite

正在开展一个项目。我想将学生的详细信息插入到sqlite数据库中,但是我在android监视器中收到一条错误“TABLE AttendanceList没有名为surname的列”,我确实有这个colunm。我被困了好几天,请帮助。

这是我的代码。

DatabaseHandler.java

public class DatabaseHandler extends SQLiteOpenHelper {
// All Static variables
// Database Version
private static final int DATABASE_VERSION = 1;

// Database Name
private static final String DATABASE_NAME = "StudentAttendance";

// Contacts table name
private static final String TABLE_AttendanceList = "AttendanceList";

// Contacts Table Columns names
private static final String KEY_surname = "surname";
private static final String KEY_ID = "id";
private static final String KEY_reg_no = "reg_no";
private static final String KEY_firstname = "firstname";
private static final String KEY_lastname = "lastname";


public DatabaseHandler(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

// Creating Tables
@Override
public void onCreate(SQLiteDatabase db) {
    String CREATE_AttendanceList_TABLE = "CREATE TABLE " + TABLE_AttendanceList + "("
            + KEY_ID + " INTEGER PRIMARY KEY,"
            + KEY_reg_no + " TEXT"
            + KEY_firstname + " TEXT"
            + KEY_lastname + "TEXT"
            + KEY_surname +  "TEXT"  + ")";
    db.execSQL(CREATE_AttendanceList_TABLE);
}

// Upgrading database
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // Drop older table if existed
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_AttendanceList);

    // Create tables again
    onCreate(db);
}

/**
 * All CRUD(Create, Read, Update, Delete) Operations
 */

// Adding new contact
void addAttendanceList (AttendanceList AttendanceList) {
    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues values = new ContentValues();
    values.put(KEY_ID, AttendanceList.getID());
    values.put(KEY_reg_no, AttendanceList.getRegNo()); //  RegNo
    values.put(KEY_firstname, AttendanceList.getFirstname());
    values.put(KEY_lastname, AttendanceList.getLastname()); // lasttname
    values.put(KEY_surname, AttendanceList.getSurname());// surname

    // Inserting Row
    db.insert(TABLE_AttendanceList,null,values);
    db.close(); // Closing database connection
}

// Getting single contact
AttendanceList getAttendanceList(int id) {
    SQLiteDatabase db = this.getReadableDatabase();

    Cursor cursor = db.query(TABLE_AttendanceList, new String[] { KEY_ID,
                    KEY_reg_no, KEY_firstname, KEY_lastname, KEY_surname }, KEY_ID + "=?",
            new String[] { String.valueOf(id) }, null, null, null, null);
    if (cursor != null)
        cursor.moveToFirst();

    AttendanceList AttendanceList = new AttendanceList(Integer.parseInt(cursor.getString(0)),
            cursor.getString(1), cursor.getString(2), cursor.getString(3),cursor.getString(4));
    // return AttendanceList
    return AttendanceList;
}

// Getting All details
public List<AttendanceList> getAllAttendanceList() {
    List<AttendanceList> contactList = new ArrayList<AttendanceList>();
    // Select All Query
    String selectQuery = "SELECT  * FROM " + TABLE_AttendanceList;

    SQLiteDatabase db = this.getWritableDatabase();
    Cursor cursor = db.rawQuery(selectQuery, null);

    // looping through all rows and adding to list
    if (cursor.moveToFirst()) {
        do {
            AttendanceList AttendanceList = new AttendanceList();
            AttendanceList.setID(Integer.parseInt(cursor.getString(0)));
            AttendanceList.setRegNo(cursor.getString(1));
            AttendanceList.setFirstname(cursor.getString(2));
            AttendanceList.setLastname(cursor.getString(3));
            AttendanceList.setSurname(cursor.getString(4));
            // Adding Attendance to list
            contactList.add(AttendanceList);
        } while (cursor.moveToNext());
    }

    // return Attendancelist
    return contactList;
}

// Updating single Attendance List
public int updateContact(AttendanceList AttendanceList) {
    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues values = new ContentValues();
    values.put(KEY_reg_no, AttendanceList.getRegNo());
    values.put(KEY_firstname, AttendanceList.getFirstname());
    values.put(KEY_lastname, AttendanceList.getLastname());
    values.put(KEY_surname, AttendanceList.getSurname());

    // updating row
    return db.update(TABLE_AttendanceList, values, KEY_ID + " = ?",
            new String[] { String.valueOf(AttendanceList.getID()) });
}

// Deleting single List item
public void deleteListItem(AttendanceList AttendanceList) {
    SQLiteDatabase db = this.getWritableDatabase();
    db.delete(TABLE_AttendanceList, KEY_ID + " = ?",
            new String[] { String.valueOf(AttendanceList.getID()) });
    db.close();
}


// Getting List Count
public int getListCount() {
    String countQuery = "SELECT  * FROM " + TABLE_AttendanceList;
    SQLiteDatabase db = this.getReadableDatabase();
    Cursor cursor = db.rawQuery(countQuery, null);
    cursor.close();

    // return count
    return cursor.getCount();
}

}

StudentTake100Activity.java

public class StudentTake100Activity extends AppCompatActivity {
private ListView lvStudentlist;
private StudentListAdapter adapter;
private List<StudentList> mStudentList;
private CheckBox checkBox;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_student_take100);

    lvStudentlist= (ListView) findViewById(R.id.listview_studentlist);


    final DatabaseHandler db = new DatabaseHandler(this);

    mStudentList = new ArrayList<>();
    //Add sample data for list
    //We can get data from DB, webservice here
    mStudentList.add(new StudentList(1, "U11EE1001", "Bargo","S.","Mayafi"));
    mStudentList.add(new StudentList(2, "U11EE1002", "Barnsbas","Snake.","Maciji"));
    mStudentList.add(new StudentList(3, "U11EE1004", "Adamu","Tanko.","Sadau"));
    mStudentList.add(new StudentList(4, "U11EE1005", "Munzali","","Cire Tallafi"));


    //Init adapter
    adapter = new StudentListAdapter(getApplicationContext(), mStudentList);
    lvStudentlist.setAdapter(adapter);
    checkBox = (CheckBox) findViewById(R.id.checkBox);

    lvStudentlist.setOnItemClickListener(new AdapterView.OnItemClickListener() {
        @Override
        public void onItemClick(AdapterView<?> parent, View view, int position, long id) {

            StudentList studentList = (StudentList)parent.getItemAtPosition(position);

            String reg_no = studentList.getReg_no();
            String firstname = studentList.getFirstname();
            String lastname = studentList.getLasttname();
            String surname = studentList.getSurname();

            db.addAttendanceList(new AttendanceList(reg_no,firstname,lastname,surname));


        }
    });

}

}

AttendaneList.java

public class AttendanceList {
//private variables
int _id;
String _reg_no;
String _firstname;
String _lastname;
String _surname;

// Empty constructor
public AttendanceList(){

}
// constructor
public AttendanceList(int id, String _reg_no, String _firstname, String _lastname, String _surname){
    this._id = id;
    this._reg_no = _reg_no;
    this._firstname = _firstname;
    this._lastname = _lastname;
    this._surname = _surname;
}

// constructor
public AttendanceList(String _reg_no, String _firstname, String _lastname, String _surname){
    this._reg_no = _reg_no;
    this._firstname = _firstname;
    this._lastname = _lastname;
    this._surname = _surname;
}
// getting ID
public int getID(){
    return this._id;
}

// setting id
public void setID(int id){
    this._id = id;
}

// getting regNo
public String getRegNo(){
    return this._reg_no;
}

// setting regNo
public void setRegNo(String reg_no){
    this._reg_no = reg_no;
}

// getting firstname
public String getFirstname(){
    return this._firstname;
}

// setting firstname
public void setFirstname(String firstname){
    this._firstname = firstname;
}

// getting lastname
public String getLastname(){
    return this._lastname;
}

// setting lastname
public void setLastname(String lastname){
    this._lastname = lastname;
}
// getting surname
public String getSurname(){
    return this._surname;
}

// setting surname
public void setSurname(String surname){
    this._surname = surname;
}

}

logcat image

syntax error

06-22 10:58:04.576 2936-2961/com.sunusi2sim.mobileattendance E/Surface: getSlotFromBufferLocked: unknown buffer: 0xeeab85e0
06-22 10:58:05.957 2936-2936/com.sunusi2sim.mobileattendance E/SQLiteLog: (1) near ")": syntax error
06-22 10:58:05.959 2936-2936/com.sunusi2sim.mobileattendance E/InputEventReceiver: Exception dispatching input event.
06-22 10:58:05.959 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI: Exception in MessageQueue callback: handleReceiveCallback
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI: android.database.sqlite.SQLiteException: near ")": syntax error (code 1): , while compiling: CREATE TABLE AttendanceList(id INTEGER PRIMARY KEY,reg_no TEXT,firstname TEXT,lastname TEXT,surname TEXT,)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:887)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:498)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java:31)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteDatabase.executeSql(SQLiteDatabase.java:1674)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1605)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at com.sunusi2sim.mobileattendance.DatabaseHandler.onCreate(DatabaseHandler.java:47)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:251)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:163)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at com.sunusi2sim.mobileattendance.DatabaseHandler.addAttendanceList(DatabaseHandler.java:66)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at com.sunusi2sim.mobileattendance.StudentTake100Activity$1.onItemClick(StudentTake100Activity.java:54)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.widget.AdapterView.performItemClick(AdapterView.java:310)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.widget.AbsListView.performItemClick(AbsListView.java:1145)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.widget.AbsListView$PerformClick.run(AbsListView.java:3042)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.widget.AbsListView.onTouchUp(AbsListView.java:3891)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.widget.AbsListView.onTouchEvent(AbsListView.java:3656)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.View.dispatchTouchEvent(View.java:9294)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2547)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2240)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2553)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2254)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2553)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2254)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2553)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2254)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2553)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2254)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2553)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2254)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2553)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2254)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at com.android.internal.policy.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2403)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at com.android.internal.policy.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1737)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.app.Activity.dispatchTouchEvent(Activity.java:2765)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.support.v7.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:60)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at com.android.internal.policy.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:2364)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.View.dispatchPointerEvent(View.java:9514)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:4230)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:4096)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3642)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:3695)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:3661)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:3787)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:3669)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:3844)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:3642)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:     at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:3695)
06-22 10:58:05.961 2936-2936/com.sunusi2sim.mobileattendance E/MessageQueue-JNI:    at android.view.ViewRootImpl$InputS

ViewAttendanceActivity

public class ViewAttendanceActivity extends AppCompatActivity {
private ListView lvStudentlist;
private StudentListAdapter adapter;
private List<StudentList> mStudentList;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_view_attendance);

    lvStudentlist= (ListView) findViewById(R.id.listview_studentlist);

    DatabaseHandler db = new DatabaseHandler(this);

    SQLiteDatabase connection;
    connection = db.getReadableDatabase();

    Cursor result=connection.rawQuery("SELECT  * FROM AttendanceList", null);//  database query for all AttendanceList in your table
    while(result.moveToNext ())
        mStudentList.add(new StudentList(result.getInt(0),result.getString(1),result.getString(2),result.getString(3),result.getString(4)));

    mStudentList = new ArrayList<>();

    adapter = new StudentListAdapter(getApplicationContext(), mStudentList);
    lvStudentlist.setAdapter(adapter);


}

}

错误

06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:FATAL EXCEPTION:main 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:进程:com.sunusi2sim.mobileattendance,PID:1650 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:java.lang.RuntimeException:无法启动活动ComponentInfo {com.sunusi2sim.mobileattendance / com.sunusi2sim.mobileattendance.ViewAttendanceActivity}:java。 lang.NullPointerException:尝试在空对象引用上调用接口方法'boolean java.util.List.add(java.lang.Object)' 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2416) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread.-wrap11(ActivityThread.java) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1344) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.os.Handler.dispatchMessage(Handler.java:102) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.os.Looper.loop(Looper.java:148) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread.main(ActivityThread.java:5417) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at java.lang.reflect.Method.invoke(Native Method) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:726) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:引起:java.lang.NullPointerException:尝试调用接口方法'boolean java.util.List.add(java.lang.Object )'在空对象引用上 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at com.sunusi2sim.mobileattendance.ViewAttendanceActivity.onCreate(ViewAttendanceActivity.java:31) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.Activity.performCreate(Activity.java:6237) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread.-wrap11(ActivityThread.java) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1344) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.os.Handler.dispatchMessage(Handler.java:102) 06-24 17:41:05.354 1650-1650 / com.sunusi2sim.mobileattendance E / AndroidRuntime:at android.os.Looper.loop(Looper.java:148)

1 个答案:

答案 0 :(得分:2)

你的创建表查询搞砸了。列名称及其类型之间应该有一个空格,并且还缺少逗号。使用此

@Override
public void onCreate(SQLiteDatabase db) {
    String CREATE_AttendanceList_TABLE = "CREATE TABLE " + TABLE_AttendanceList + "("
        + KEY_ID + " INTEGER PRIMARY KEY,"
        + KEY_reg_no + " TEXT,"
        + KEY_firstname + " TEXT,"
        + KEY_lastname + " TEXT," 
        + KEY_surname +  " TEXT"  + ")"; 
    db.execSQL(CREATE_AttendanceList_TABLE);
}

您必须先卸载应用程序,然后再运行更新的代码。