我为本地sqlite数据库创建了应 用程序,但它没有运行。请告诉我解决方案

问题描述 投票:0回答:1

这是DatabaseHelper.java类,在这个类中我为SQLite Database编写查询。我认为查询没有任何问题。

package com.example.ankurnamikaze.myapp;

import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import static android.R.attr.id;
import static android.R.attr.name;

public class DatabaseHelper extends SQLiteOpenHelper {
SQLiteDatabase db;
public static final String DATABASE_NAME = "notes_db";
public static final int DATABASE_VERSION = 1;
public static final String TABLE_NAME = "notes";
public static final String COL_ID = "id";
public static final String COL_NAME = "name";
public static final String COL_PASS = "pass";

此方法用于创建数据库。

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

@Override
public void onCreate(SQLiteDatabase db) {
    db.execSQL("create table " + TABLE_NAME + " (" +COL_ID + " integer autoincrement," + COL_NAME + " text," + COL_PASS+ " text)");

}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    db.execSQL("drop table if exists " + TABLE_NAME);
    onCreate(db);
}

// INSERTING ROW IN DATABASE

public void insertData(int id, String name, String pass){
    db = this.getWritableDatabase();
    ContentValues values = new ContentValues();
    values.put(COL_ID, id);
    values.put(COL_NAME, name);
    values.put(COL_PASS, pass);
    db.insert(TABLE_NAME, null, values);
}
}

这是MainActivity.java类。我认为我在定义DatabaseHelper类时遇到了问题,因为之前我在onCreate方法之外定义它会使应用程序崩溃,然后我看到一些代码告诉我在onCreate方法中定义它,但它仍然不适合我。

package com.example.ankurnamikaze.myapp;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

import static android.R.attr.id;
import static android.icu.lang.UCharacter.GraphemeClusterBreak.T;

public class MainActivity extends AppCompatActivity {
DatabaseHelper databaseHelper;
EditText name, password;
String user_name, user_pass;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    databaseHelper = new DatabaseHelper(this);
    setContentView(R.layout.activity_main);
    name = (EditText)findViewById(R.id.user_name);
    password = (EditText)findViewById(R.id.user_pass);
    user_name = String.valueOf(name.getText());
    user_pass = String.valueOf(password.getText());
    databaseHelper.insertData(id, user_name, user_pass);
}
}

这是activiy_main.xml,在此我创建了属性。我不认为这是问题的根源。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="com.example.ankurnamikaze.myapp.MainActivity">


<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="USERNAME"
android:id="@+id/user_name"/>

<EditText
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="PASSWORD"/>

<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center_horizontal"
    android:text="sumbit"
    android:id="@+id/button" />

</LinearLayout>
java android xml sqlite sqliteopenhelper
1个回答
1
投票

有一些错误/问题。

问题1

您编写了" integer autoincrement,"这会导致语法错误,因为AUTOINCREMENT关键字只能与INTEGER PRIMARY KEY一起使用(说不建议使用它,因为INTEGER PRIMARY KEY效率更高且结果非常相似,即自动生成唯一的id(实际上它只会使id成为任何情况下rowid的别名)。)SQLite Autoincrement

EG

AUTOINCREMENT关键字会占用额外的CPU,内存,磁盘空间和磁盘I / O开销,如果不是严格需要,应该避免使用。通常不需要它

该错误将导致以下内容: -

09-19 07:32:10.040 7200-7200/? E/SQLiteLog: (1) near "autoincrement": syntax error
09-19 07:32:10.040 7200-7200/? D/AndroidRuntime: Shutting down VM
09-19 07:32:10.040 7200-7200/? W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0xa62e9288)
09-19 07:32:10.044 7200-7200/? E/AndroidRuntime: FATAL EXCEPTION: main
    java.lang.RuntimeException: Unable to start activity ComponentInfo{so52399661.so52399661/so52399661.so52399661.MainActivity}: android.database.sqlite.SQLiteException: near "autoincrement": syntax error (code 1): , while compiling: create table notes (id integer autoincrement,name text,pass text)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2059)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
        at android.app.ActivityThread.access$600(ActivityThread.java:130)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:137)
        at android.app.ActivityThread.main(ActivityThread.java:4745)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:511)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
        at dalvik.system.NativeStart.main(Native Method)
     Caused by: android.database.sqlite.SQLiteException: near "autoincrement": syntax error (code 1): , while compiling: create table notes (id integer autoincrement,name text,pass text)
        at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
        at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:882)
        at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:493)
        at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
        at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
        at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java:31)
        at android.database.sqlite.SQLiteDatabase.executeSql(SQLiteDatabase.java:1663)
        at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1594)
        at so52399661.so52399661.DatabaseHelper.onCreate(DatabaseHelper.java:23)
        at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:252)
        at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)
        at so52399661.so52399661.DatabaseHelper.insertData(DatabaseHelper.java:38)
        at so52399661.so52399661.MainActivity.onCreate(MainActivity.java:24)
        at android.app.Activity.performCreate(Activity.java:5008)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084) 
        at android.app.ActivityThread.access$600(ActivityThread.java:130) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195) 
        at android.os.Handler.dispatchMessage(Handler.java:99) 
        at android.os.Looper.loop(Looper.java:137) 
        at android.app.ActivityThread.main(ActivityThread.java:4745) 
        at java.lang.reflect.Method.invokeNative(Native Method) 
        at java.lang.reflect.Method.invoke(Method.java:511) 
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
        at dalvik.system.NativeStart.main(Native Method) 

相反,我建议只编码: -

db.execSQL("create table " + TABLE_NAME + " (" +COL_ID + " INTEGER PRIMARY KEY," + COL_NAME + " TEXT," + COL_PASS+ " TEXT)");

问题2

您没有在布局中定义id user_pass。

问题3

id无法解析(请参阅下面这不是必需的)。

以下是固定代码(请参阅注释),其中包含一些其他代码,用于列出数据库中的表: -

activity_main.xml(id user_pass已添加到PASSWORD EditText): -

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">


    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="USERNAME"
        android:id="@+id/user_name"/>

    <EditText
        android:id="@+id/user_pass"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="PASSWORD"/>

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:text="sumbit"
        android:id="@+id/button" />

</LinearLayout>

DatabaseHelper.java(见评论): -

public class DatabaseHelper extends SQLiteOpenHelper {
    SQLiteDatabase db;
    public static final String DATABASE_NAME = "notes_db";
    public static final int DATABASE_VERSION = 1;
    public static final String TABLE_NAME = "notes";
    public static final String COL_ID = "id";
    public static final String COL_NAME = "name";
    public static final String COL_PASS = "pass";

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

    @Override
    public void onCreate(SQLiteDatabase db) {
        //db.execSQL("create table " + TABLE_NAME + " (" +COL_ID + " integer autoincrement," + COL_NAME + " text," + COL_PASS+ " text)"); //<<<<<<<<<< ERROR
        db.execSQL("create table " + TABLE_NAME + " (" +COL_ID + " INTEGER PRIMARY KEY," + COL_NAME + " TEXT," + COL_PASS+ " TEXT)");

    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        db.execSQL("drop table if exists " + TABLE_NAME);
        onCreate(db);
    }

// INSERTING ROW IN DATABASE

    //<<<<<<<<<< as INTEGER PRIMARY KEY then id will be automatically generated
    public void insertData(String name, String pass){
        db = this.getWritableDatabase();
        ContentValues values = new ContentValues();
        //values.put(COL_ID, id); not needed will autogenerate
        values.put(COL_NAME, name);
        values.put(COL_PASS, pass);
        db.insert(TABLE_NAME, null, values);
    }
}

MainActivity.java(见评论): -

public class MainActivity extends AppCompatActivity {
    DatabaseHelper databaseHelper;
    EditText name, password;
    String user_name, user_pass;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        databaseHelper = new DatabaseHelper(this);
        setContentView(R.layout.activity_main);
        name = (EditText)findViewById(R.id.user_name);
        password = (EditText)findViewById(R.id.user_pass);
        user_name = String.valueOf(name.getText());
        user_pass = String.valueOf(password.getText());
        //databaseHelper.insertData(id, user_name, user_pass); //<<<<<<<<<< got rid of id
        databaseHelper.insertData(user_name, user_pass);

        //<<<<<<<<<< ADDED to List the tables
        Cursor csr = databaseHelper.getWritableDatabase().query("sqlite_master",null,null,null,null,null,null );
        while (csr.moveToNext()) {
            Log.d("TABLES","Found table " + csr.getString(csr.getColumnIndex("name")));
        }
        csr.close();
    }
}

日志中的结果: -

09-19 07:10:20.628 6977-6977/so52399661.so52399661 D/TABLES: Found table android_metadata
    Found table notes

即你注意表存在,android_metedata是由DatabaseHelper作为其子类的SQLiteOpenhelper类创建的表。它包含区域设置。

© www.soinside.com 2019 - 2024. All rights reserved.