0

我在允许类访问我的数据库的方法上收到错误消息。错误发生在 .getReadableDatabase()。收到的错误如下。不知道如何解决这个错误。

 Cannot make a static reference to the non-static method getReadableDatabase() from the type SQLiteOpenHelper

方法:

 public static boolean vaidateUser(String username, String password) {
        Cursor c = getReadableDatabase().rawQuery(
                "SELECT * FROM " + TABLE_NAME_CREDENTIALS + " WHERE "
                        + COLUMN_NAME_USERNAME + "='" + username +"'AND "+COLUMN_NAME_PASSWORD+"='"+password+"'" ,  null);
       if (c.getCount()>0)
          return true;
          return false;

用于调用此方法:

  lsLogin.setOnClickListener (new OnClickListener() {

                @Override
                public void onClick(View v) {
                    //check login
                    String username = lsUsername.getText().toString();
                    String password = lsPassword.getText().toString();
                    try{
                        if(LoginDB.vaidateUser(username,password)) {
                            Intent goToNextActivity = new Intent(getApplicationContext(), menu.class);
                            startActivity(goToNextActivity);

                                Toast.makeText(LoginScrExample.this,"Login Sucessful",Toast.LENGTH_LONG).show();
                            }else{
                                Toast.makeText(LoginScrExample.this,"Invalid Username/Password",Toast.LENGTH_LONG).show();
                            }

                            }
4

3 回答 3

3

这意味着您需要一个对象的实例来调用此方法,因为它不是static

执行以下操作:Cursor c = new YourObject().getReadableDatabase()...

或者也使被调用的方法static

于 2012-08-23T15:28:32.043 回答
3

由于您正在调用非静态方法,因此引发了错误:

getReadableDatabase();

您在静态方法中调用的任何方法也必须是静态的。

要修复它,要么从静态方法中删除静态,要么将静态添加到所有使用的方法中。

于 2012-08-23T15:29:08.173 回答
0

它是一种方法SQLiteOpenHelper

所以改为这样做:

Cursor c = new SQLiteOpenHelper().getReadableDatabase()..

或者

SQLiteOpenHelper soh = new SQLiteOpenHelper();
Cursor c = soh().getReadableDatabase()..
于 2012-08-23T15:31:09.343 回答