Запрос к базе данных не работает в комнате SQLite

Я новичок в Android. Я пытаюсь изучить Android и столкнулся с проблемой. Во время работы с SQLite выполняется моя операция вставки. Мой пользователь loadAll также выполняется. Но при использовании параметров для получения пользователя операция не выполняется. Я делюсь кодами в следующем. Заранее спасибо за помощь.

AppHome.java

package com.impresscapital.iclapp;

import android.content.Intent;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;

import com.impresscapital.iclapp.dbobj.User;
import com.impresscapital.iclapp.util.ToastMessage;
import com.impresscapital.iclapp.util.UserSigninAuthentication;

public class AppHome extends AppCompatActivity {

    private TextView mUsernameTextView;
    private TextView mPasswordTextView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_app_home);

        initiateUI();
    }

    private void initiateUI(){
        mUsernameTextView=findViewById(R.id.editTextUsername);
        mPasswordTextView=findViewById(R.id.editTextPassword);
    }

    public void signUpPageLoader(View view){
        Intent registrationPageIntent=new Intent(AppHome.this,RegistrationPage.class);
        startActivity(registrationPageIntent);

    }

    @Override
    protected void onResume() {
        super.onResume();
    }

    public void signInUser(View view){
        try {
            String username=mUsernameTextView.getText().toString();
            String password=mPasswordTextView.getText().toString();
            UserSigninAuthentication userSigninAuthentication=new UserSigninAuthentication();
            if (userSigninAuthentication.authenticate(username, password, getApplicationContext())) {
                Intent userHomePageIntent = new Intent(AppHome.this, UserHome.class);
                startActivity(userHomePageIntent);
            } else {
                mPasswordTextView.setBackground(new ColorDrawable(Color.RED));
                mUsernameTextView.setBackground(new ColorDrawable(Color.RED));
                ToastMessage.toastMessage(this, "Username or password do not match");
                onResume();
            }
        }catch (NullPointerException e){
            mPasswordTextView.setBackground(new ColorDrawable(Color.RED));
            mUsernameTextView.setBackground(new ColorDrawable(Color.RED));
            ToastMessage.toastMessage(this, "Username or password do not match");

        }
    }
}

UserSigninAuthentication.java

package com.impresscapital.iclapp.util;

import android.content.Context;
import android.util.Log;

import com.impresscapital.iclapp.database.AppDatabase;
import com.impresscapital.iclapp.database.AppExecutors;
import com.impresscapital.iclapp.dbobj.User;

public class UserSigninAuthentication {

    private AppDatabase mDb;
    private Boolean isAuthenticate=false;

    public boolean authenticate(final String username, final String password,Context context){
        dataBaseOperation(username,password,context);
        return isAuthenticate;
    }

    public void dataBaseOperation(final String username, final String password, final Context context){
        AppExecutors.getsInstance().getDiskIO().execute(new Runnable() {
            @Override
            public void run() {
                try {
                    Log.d("DB","Inside db opt");
                    User user = mDb.userDao().loadUser(username, password);
                    if (user != null){
                        Log.d("DB","user found");
                        //ToastMessage.toastMessage(context,user.getUserID()+user.getEmail());
                        isAuthenticate = true;
                    }
                }catch (NullPointerException n){
                    isAuthenticate=false;
                }
            }
        });
    }
}

UserDao.java

package com.impresscapital.iclapp.dao;

import android.arch.persistence.room.Dao;
import android.arch.persistence.room.Delete;
import android.arch.persistence.room.Insert;
import android.arch.persistence.room.Query;
import android.arch.persistence.room.Update;

import com.impresscapital.iclapp.dbobj.User;

import java.util.List;

@Dao
public interface UserDao {


    @Query("Select * from user_table where username=:username and password=:password")
    User loadUser(String username,String password);

    @Query("Select * from user_table")
    List<User> retrieveAllUser();
    @Insert
    void registerUser(User user);

    @Update
    void updateUser(User user);

    @Delete
    void deleteUser(User user);
}

Я получил всех пользователей из другого класса. Код журнала

List<User> users=mDb.userDao().retrieveAllUser();
                for(User user1:users){
                    Log.d("Db working",user1.getUsername()+" "+user1.getPassword());
                }
                finish();

И сообщение журнала:

2018-10-29 13:11:47.210 11488-13813/com.impresscapital.iclapp D/Db working: y y
2018-10-29 13:11:47.210 11488-13813/com.impresscapital.iclapp D/Db working: g 1

Класс AppDatabase загружен для вашего удобства:

AppDatabase.claa

package com.impresscapital.iclapp.database;


import android.arch.persistence.room.Database;
import android.arch.persistence.room.Room;
import android.arch.persistence.room.RoomDatabase;
import android.arch.persistence.room.TypeConverter;
import android.arch.persistence.room.TypeConverters;
import android.content.Context;
import android.util.Log;

import com.impresscapital.iclapp.dao.UserDao;
import com.impresscapital.iclapp.dbobj.User;
import com.impresscapital.iclapp.util.DateConverter;

@Database(entities = {User.class},version = 1, exportSchema = false)
@TypeConverters({DateConverter.class})
public abstract class AppDatabase extends RoomDatabase {

    private static final String LOG_CAT=AppDatabase.class.getSimpleName();
    private static final Object LOCK=new Object();
    private static final String DATABASE_NAME = "db_icl_app";
    private static AppDatabase sInstance;

    public static AppDatabase getInstance(Context context){
        if (sInstance==null){
            synchronized (LOCK){
                Log.d(LOG_CAT,"Creating new Database");
                sInstance=Room.databaseBuilder(context.getApplicationContext(),
                        AppDatabase.class,AppDatabase.DATABASE_NAME).build();
            }

        }
        Log.d(LOG_CAT,"Getting the database instance");
        return sInstance;
    }

    public abstract UserDao userDao();
}

UserSigninAuthentication.class

package com.impresscapital.iclapp.util;

import android.content.Context;
import android.util.Log;

import com.impresscapital.iclapp.database.AppDatabase;
import com.impresscapital.iclapp.database.AppExecutors;
import com.impresscapital.iclapp.dbobj.User;

import java.util.List;

public class UserSigninAuthentication {

    private AppDatabase mDb;
    private Boolean isAuthenticate=false;

    public boolean authenticate(final String username, final String password,Context context){
        dataBaseOperation(username.trim(),password.trim(),context);
        return isAuthenticate;
    }

    public void dataBaseOperation(final String username, final String password, final Context context){

        Log.d("Username","username: "+username);
        Log.d("Username","username length: "+username.length());
        Log.d("Password","password:"+password);
        Log.d("Password","password length:"+password.length());
        AppExecutors.getsInstance().getDiskIO().execute(new Runnable() {
            @Override
            public void run() {
                try {
                    List<User> users=mDb.userDao().retrieveAllUser();
                    for(User user1:users){
                        Log.d("Db working","Username:"+user1.getUsername()+" Password:"+user1.getPassword());
                    }
                    Log.d("DB","Inside db opt");
                    List<User> user1 = mDb.userDao().loadUser(username, password);
                    Log.d("Total Users after query","Tot"+ user1.size());
                    //ToastMessage.toastMessage(context,user.getUserID()+user.getEmail());
                    isAuthenticate = true;
                }catch (NullPointerException n){
                    isAuthenticate=false;
                }
                Log.d("isAuthenticate Variable", isAuthenticate.toString());
            }
        });
    }
}

retrieveAllUser работает?

sasikumar 29.10.2018 07:29

Какой именно запрос не работает?

Arahasya 29.10.2018 07:30

Где вы назвали этот метод: retrieveAllUser()

Ümañg ßürmån 29.10.2018 07:39

@Query ("Выбрать * из таблицы_пользователей, где имя пользователя =: имя пользователя и пароль =: пароль") Пользователь loadUser (имя пользователя в строке, пароль в строке); этот запрос не работает

Rashedur Rahman 29.10.2018 07:40

Я вызвал метод retrieveAllUser () в другом классе, который здесь не упоминается.

Rashedur Rahman 29.10.2018 07:42

Вы получаете какую-нибудь ошибку?

Sagar Zala 29.10.2018 07:50

Сообщение об ошибке не отображается

Rashedur Rahman 29.10.2018 08:10
1
7
968
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Попробуйте вместо этого использовать ' '.

@Query("Select * from user_table where username='username' and password= 'password'")

параметр не может быть передан таким образом в android. Я обнаружил, что моя проблема была в другом месте. Я думаю, может быть, по какой-то причине класс AppExecutor не инициализировался. Вот почему была показана эта ошибка. Сделал все с нуля и теперь вроде нормально работает. Спасибо за помощь.

Rashedur Rahman 01.11.2018 10:24
Ответ принят как подходящий

попробуйте выполнить следующий запрос с вашим кодом.

SELECT * FROM user_table WHERE username like :username and password like :password

как упоминалось в комментариях, инициализация mDb перед запросом db работала.

Ваша таблица данных имеет точное совпадение с введенными вами данными? попробуйте добавить LIMIT 1 в последний из вышеуказанных запросов, если ваш запрос может возвращать более одного результата.

karan 29.10.2018 10:12

Некоторое время отлаживаю. В процессе отладки я обнаружил, что следующая строка не работает: List <User> user1 = mDb.userDao (). LoadUser (имя пользователя, пароль);

Rashedur Rahman 29.10.2018 10:51

это может быть полезно, если вы можете опубликовать код для класса appdatabase.

karan 29.10.2018 10:53

похоже, вы забыли инициализировать переменную mdb перед ее использованием.

karan 29.10.2018 10:54

Но работает List<User> users=mDb.userDao().retrieveAllUser(); for(User user1:users){ Log.d("Db working","Username:"+user1.getUsername()+" Password:"+user1.getPassword()); }

Rashedur Rahman 29.10.2018 11:03

вы должны инициализировать его, прежде чем использовать здесь mDb.userDao().retrieveAllUser();, разместите полный код для класса, в котором вы его использовали.

karan 29.10.2018 11:05

Я отредактировал сообщение с полным классом, в котором я использовал метод. Заранее спасибо за помощь мне

Rashedur Rahman 29.10.2018 11:23

Спасибо за помощь :) Я забыл инициализировать переменную mDb

Rashedur Rahman 30.10.2018 06:22

Другие вопросы по теме