Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sqlite/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/file/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 不幸的是,此应用程序已停止工作(SQLiteDatabase)_Android_Sqlite_Android Sqlite - Fatal编程技术网

Android 不幸的是,此应用程序已停止工作(SQLiteDatabase)

Android 不幸的是,此应用程序已停止工作(SQLiteDatabase),android,sqlite,android-sqlite,Android,Sqlite,Android Sqlite,我有一个问题:我写了一个应用程序,但是SQLiteDatabase不工作 我的数据库类代码: package com.example.frauprinzssapp; import android.content.ContentValues; import android.content.Context; import android.database.DatabaseErrorHandler; import android.database.sqlite.SQLiteDatabase; imp

我有一个问题:我写了一个应用程序,但是SQLiteDatabase不工作

我的数据库类代码:

package com.example.frauprinzssapp;

import android.content.ContentValues;
import android.content.Context;
import android.database.DatabaseErrorHandler;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class database extends SQLiteOpenHelper{

public static final String DB_NAME = "users.db";
public static final String DB_TABLENAME = "users_table";
public static final String COL_1 = "id";
public static final String COL_2 = "name";
public static final String COl_3 = "class";
public static final String COL_4 = "right";

public database(Context context) {
    super(context, DB_NAME, null, 1);

}

@Override
public void onCreate(SQLiteDatabase db) {
    db.execSQL("create table "+DB_TABLENAME+"(id INTEGER PRIMARY KEY       AUTOINCREMENT, name TEXT, class TEXT, right INTEGER)");
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    db.execSQL("DROP TABLE IF EXIST "+DB_TABLENAME);
    onCreate(db);
}

public boolean insertdata(String name, String clas){
    SQLiteDatabase db = this.getWritableDatabase();
    ContentValues cv = new ContentValues();
    cv.put(COL_2, name);
    cv.put(COl_3, clas);
    cv.put(COL_4, 0);
    long result = db.insert(DB_TABLENAME, null, cv);
    if (result == -1){
        return false;
    }else{
        return true;
    }
}
}
主要代码是:

package com.example.frauprinzssapp;

import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;

public class Main extends Activity {

List<String> addusers = new ArrayList<String>();
database myDb;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    myDb = new database(this);
}
//-----change view voids-----
public void main(View view){
    setContentView(R.layout.main);
}
public void adduser(View view){
    setContentView(R.layout.adduser);
}
public void removeuser(View view){
    setContentView(R.layout.removeuser);
}

//------actions------
public void add(){
    EditText name = (EditText) findViewById(R.id.aun);
    EditText clas = (EditText) findViewById(R.id.auc);
    if (name.toString() == null || clas.toString() == null){
        Toast.makeText(Main.this, "please fill in all textfields!",      Toast.LENGTH_LONG);
        return;
    }
try{
    myDb.insertdata(name.toString(), clas.toString());
    Toast.makeText(Main.this, "added user "+name.toString()+"!",   Toast.LENGTH_LONG);
}catch(Exception e){
    Toast.makeText(Main.this, "[ERROR] Could not create user maybe its   already created!", Toast.LENGTH_LONG);
}
}
public void remove(){

}
public void show(){

}
}
使“添加空心”运行的步骤 请现在它只是将随机内容放入sqlite请参阅帮助

试试

//------actions------
public void add(){
  EditText name = (EditText) findViewById(R.id.aun);
  EditText clas = (EditText) findViewById(R.id.auc);
  String name1 = name.getText().toString();
  String clas1 = clas.getText().toString();
  if (name1.equals("") || clas1.equals("")){
    Toast.makeText(Main.this, "please fill in all textfields!", Toast.LENGTH_LONG);
    return;
  }
  try{
    myDb.insertdata(name1, clas1);
    Toast.makeText(Main.this, "added user "+name1+"!", Toast.LENGTH_LONG);
  }catch(Exception e){
    Toast.makeText(Main.this, "[ERROR] Could not create user maybe its already created!", Toast.LENGTH_LONG);
  }
}

我认为public void add应该改为public void addView view,但现在我有一个问题,它只是放了一些随机的东西来发布你的日志。然后如何跟踪你的错误。有很多人在尝试我的错误,你必须发布你的日志。
//------actions------
public void add(){
  EditText name = (EditText) findViewById(R.id.aun);
  EditText clas = (EditText) findViewById(R.id.auc);
  String name1 = name.getText().toString();
  String clas1 = clas.getText().toString();
  if (name1.equals("") || clas1.equals("")){
    Toast.makeText(Main.this, "please fill in all textfields!", Toast.LENGTH_LONG);
    return;
  }
  try{
    myDb.insertdata(name1, clas1);
    Toast.makeText(Main.this, "added user "+name1+"!", Toast.LENGTH_LONG);
  }catch(Exception e){
    Toast.makeText(Main.this, "[ERROR] Could not create user maybe its already created!", Toast.LENGTH_LONG);
  }
}