gpt4 book ai didi

android - Android数据库;解决最后几个错误

转载 作者:行者123 更新时间:2023-12-03 08:30:55 26 4
gpt4 key购买 nike

我选了两个类,并在下面的代码中将它们合并为一个类。我已接近成功,但仍然存在一些错误。我的编程环境告诉我以下错误:

第51行-类型为SQLiteDatabase的open()方法未定义

第56行-类型为SQLiteDatabase的open()方法未定义

第57行-类型为SQLiteDatabase的方法getAllEntries()未定义

第98行-无法从类型SQLiteOpenHelper静态引用非静态方法getWritableDatabase()

第99行-无效方法无法返回值(我需要在这里返回任何内容吗?)

第102行-无法从类型SQLiteOpenHelper静态引用非静态方法close()

我曾尝试重新排列代码,以防出现问题。我不确定它说“类型[type]的方法未定义”是什么意思。使用Google,我无法确定这些错误消息的含义。

任何帮助将不胜感激。

package com.example.databaseProject;

import android.os.Bundle;
import android.app.Activity;
import android.content.*;
import android.content.DialogInterface.*;
import android.database.*;
import android.database.sqlite.*;
import android.util.*;
import android.view.*;
import android.view.View.*;
import android.widget.*;
import android.content.Context;
import android.view.View.onclickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;



public class MainActivity extends Activity {
private SQLiteDatabase db;
private DBHelper dbHelper;
private EditText Quote;
int id=0;
public static final String KEY_ROWID="_id";
public static final String KEY_QUOTE="Quote";
private static final String TAG="DBAdapter";
private static final String DATABASE_NAME="Random";
private static final String DATABASE_TABLE="tblRandomQuotes";
private static final int DATABASE_VERSION=1;
private static final String DATABASE_CREATE="create table tblRandomQuotes (_id integer primary key autoincrement, "+"Quote text not null );";
private Context context;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//linkingButton
Button saveButton=(Button)findViewById(R.id.button1);
//add onclick listener to saveButton
saveButton.setonclickListener(mAddListener);
dbHelper=new DBHelper(this);

}
//Create an anonymous implementation of onclickListener
private onclickListener mAddListener = new onclickListener(){
public void onclick(View v){
switch(v.getId()){
case R.id.button1:
db.open(); //line 51
long id=0;
//do something when the button is clicked
try{
Quote=(EditText)findViewById(R.id.lastName1);
db.insertQuote(Quote.getText().toString()); //line 56
id=db.getAllEntries(); //line 57
Context context=getApplicationContext();
CharSequence text="The quote '"+Quote.getText()+"' was added successfully!\nQuotes Total = "+id;
int duration=Toast.LENGTH_LONG;
Toast toast=Toast.makeText(context, text, duration);
toast.show();
Quote.setText("");
}
catch(Exception ex){
Context context=getApplicationContext();
CharSequence text=ex.toString()+"ID = "+id;
int duration=Toast.LENGTH_LONG;
Toast toast=Toast.makeText(context, text, duration);
toast.show();
}
db.close();
//break;
}
}
};

public void DBAdapter(Context ctx){//I think this might go up in the constructor
this.context=ctx;
dbHelper=new DBHelper(context);
}
private class DBHelper extends SQLiteOpenHelper{
public DBHelper(Context c){
super(c,DATABASE_NAME,null,DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db){
db.execSQL(DATABASE_CREATE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){
Log.w(TAG,"Upgrading database from version "+oldVersion+" to "+newVersion+", which will destroy all old data");
db.execSQL("DROP TABLE IF EXISTS tblRandomQuotes");
onCreate(db);
}
}
public void open(){
db=DBHelper.getWritableDatabase(); //line 98
return this; //line 99
}
public void close(){
DBHelper.close(); //line 102
}
public long insertQuote(String Quote){
ContentValues initialValues=new ContentValues();
initialValues.put(KEY_QUOTE,Quote);
return db.insert(DATABASE_TABLE,null,initialValues);
}
public int getAllEntries(){
Cursor cursor=db.rawQuery("SELECT COUNT(Quote) FROM tblRandomQuotes", null);
if(cursor.moveToFirst()){
return cursor.getInt(0);
}
return cursor.getInt(0);
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}

}

最佳答案

在onCreate中,删除dbHelper=new DBHelper(this);并添加以下行

DBAdapter(this);

open();


public void open(){
db=dbHelper.getWritableDatabase(); //line 98
}

public void close(){
dbHelper.close(); //line 102
}

您应该将数据库代码放入一个类中。

关于android - Android数据库;解决最后几个错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15960369/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com