私のコードはAndroidスタジオでエラーを表示しませんでしたが、プログラムを実行すると、「このアプリが不運になるのを止める」というメッセージが表示されます。なぜですか?実行中のアプリケーションのクラッシュSQLiteコードがバックエンドで書かれている場合にのみ、それが動作しています、なぜですか?私のSQLiteデータベースがクラッシュし、Android StudioのOnfortunatley Closed App Errorを表示する理由は何ですか?
このコード行を削除するとSQLiteDatabase db = this.getWritableDatabase();
実行中にアプリケーションがクラッシュしなかったが、この行がないとすべてのコードが役に立たなかった。
主な活動
package com.example.nooh.sqlite_deletevalues;
import android.database.Cursor;
import android.support.v7.app.AlertDialog;
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;
public class MainActivity extends AppCompatActivity {
EditText editid, editname, editsurname, editmarks;
Button btn_insert;
Button btn_viewdata;
Button btn_update;
Button btn_delete;
DatabaseHelper mydb;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mydb = new DatabaseHelper(this);
editid = (EditText) findViewById(R.id.editText4);
editname = (EditText) findViewById(R.id.editText);
editsurname = (EditText) findViewById(R.id.editText2);
editmarks = (EditText) findViewById(R.id.editText3);
btn_insert = (Button) findViewById(R.id.button);
btn_viewdata = (Button) findViewById(R.id.button2);
btn_update = (Button) findViewById(R.id.button3);
btn_delete = (Button) findViewById(R.id.button4);
AddData();
viewAll();
updateData();
DeleteData();
}
public void AddData() {
btn_insert.setOnClickListener(
new View.OnClickListener() {
@Override
public void onClick(View v) {
boolean isInserted = mydb.insertData(
editname.getText().toString(),
editsurname.getText().toString(),
editmarks.getText().toString()
);
if (isInserted == true)
Toast.makeText(MainActivity.this, "Data Inserted", Toast.LENGTH_SHORT).show();
else
Toast.makeText(MainActivity.this, "Data Not Inserted", Toast.LENGTH_SHORT).show();
}
}
);
}
public void viewAll(){
btn_viewdata.setOnClickListener(
new View.OnClickListener() {
@Override
public void onClick(View v) {
Cursor res = mydb.getAllData();
if(res.getCount() == 0)
{
// Show Message
showMessage("Error", "There is no Data");
return;
}
StringBuffer buffer = new StringBuffer();
while(res.moveToNext())
{
buffer.append("Id : " + res.getString(0) + "/n");
buffer.append("Name : " + res.getString(1) + "/n");
buffer.append("SurName : " + res.getString(2) + "/n");
buffer.append("Marks : " + res.getString(3) + "/n/n");
}
// Show All Data
showMessage("Data", buffer.toString());
}
}
);
}
public void showMessage (String title, String message)
{
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setCancelable(true);
builder.setTitle(title);
builder.setMessage(message);
builder.show();
}
public void updateData(){
btn_update.setOnClickListener(
new View.OnClickListener() {
@Override
public void onClick(View v) {
Boolean isUpdated = mydb.updateData(editid.getText().toString(),
editname.getText().toString(),
editsurname.getText().toString(),
editmarks.getText().toString()
);
if(isUpdated == true)
Toast.makeText(MainActivity.this, "Data Updated", Toast.LENGTH_SHORT).show();
else
Toast.makeText(MainActivity.this, "Data Not Updated", Toast.LENGTH_SHORT).show();
}
}
);
}
public void DeleteData(){
btn_delete.setOnClickListener(
new View.OnClickListener() {
@Override
public void onClick(View v) {
Integer deleterows = mydb.deleteData("editText4");
if(deleterows > 0)
Toast.makeText(MainActivity.this, "Data Deleted", Toast.LENGTH_SHORT).show();
else
Toast.makeText(MainActivity.this, "Data Not Deleted", Toast.LENGTH_SHORT).show();
}
}
);
}
}
新しいクラス名 "DatabaseHelper.java"
package com.example.nooh.sqlite_deletevalues;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DatabaseHelper extends SQLiteOpenHelper {
public static final String DATABASE_NAME = "Student.db";
public static final String TABLE_NAME = "Student_table";
public static final String COL_1 = "ID";
public static final String COL_2 = "NAME";
public static final String COL_3 = "SURNAME";
public static final String COL_4 = "MARKS";
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table " + TABLE_NAME + "(ID INTEGER PRIMARY KEY AUTOINCREMENT, NAME TEXT, SURNAME TEXT, MARKS NUMBER)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXIST" + TABLE_NAME);
onCreate(db);
}
public Boolean insertData(String name, String surname, String marks) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put(COL_2, name);
contentValues.put(COL_3, surname);
contentValues.put(COL_4, marks);
long result = db.insert(TABLE_NAME, null, contentValues);
if (result == -1)
return false;
else
return true;
}
public Cursor getAllData() {
SQLiteDatabase db = this.getWritableDatabase();
Cursor res = db.rawQuery("select * from" + TABLE_NAME, null);
return res;
}
public Boolean updateData(String id, String name, String surname, String marks) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put(COL_1, id);
contentValues.put(COL_2, name);
contentValues.put(COL_3, surname);
contentValues.put(COL_4, marks);
db.update(TABLE_NAME, contentValues, "ID = ?", new String[]{id});
return true;
}
public Integer deleteData(String id){
SQLiteDatabase db = this.getWritableDatabase();
return db.delete(TABLE_NAME, "ID = ?" , new String[] {id});
}
}
問題は何ですか?以下のような
投稿してください。 – earthw0rmjim
テーブル名の前にスペースがありません( 'IF EXISTS'の後と' FROM'の後ろ)。 –
[不幸にもMyAppが停止しました。どのように私はこれを解決することができますか?](http://stackoverflow.com/questions/23353173/unfortunately-myapp-has-stopped-how-can-i-solve-this) – 0xDEADC0DE