如何在Android Room中创建和调用自定义查询

时间:2019-04-03 05:42:02

标签: android sql mvvm viewmodel android-room

我已经建立了一个包含3列(标题,描述,体裁)的会议室数据库。我想用用户指定的类型(喜剧,恐怖等)查询类型列,并返回结果。

DAO接口

我希望查询仅检索类型与用户选择的类型匹配的条目。

@Dao
public interface MovieDAO {
    @Query SELECT * FROM movie_table WHERE genre")
    pubic LiveData<List<Movie>> getAllMovies();
}

存储库类

在Repository.class中,我可以通过这种方式将用户选择的流派字符串传递给查询吗?

public class MovieRepository {
    private MovieDao movieDao;
    private LiveData<List<Movie>> allMovies;

    public MovieRepository(Application application) {
        MovieDatabase database = MovieDatabase.getInstance(application);
        movieDao = database.MovieDao();
        allMovies = movieDao.getAllMovies
    }

    public void findMoviesByGenre(String genre) {
        movieDao.findMoviesByGenre(genre);
    }
}

ViewModel类

我不确定在findMovieByGenre()方法中是否缺少某些内容

public class MovieViewModel exteneds AndroidViewModel {
    private MovieRepository repository;
    private LiveData<List<Movie>> allMovies

    // Constructor, 
    public MovieViewModel(@NonNull Application application) {
        super(application);
        repository = new MovieRepository(Application)
        allMovies = repository.getAllMovies();
    }

    **public void findMovieByGenre(String genre) {
        repository.findMoviesByGenre(genre);
    }**
}

活动

这是我真正挣扎的部分,活动如何调用ViewModel并传递体裁字符串参数?我尝试了以下方法,但观察返回以下错误。

无法解析方法“观察(com.example.roomexample.MainActivity,匿名android.arch.lifecycle.Observer>)”

如果我从观察中删除流派字符串,则会收到以下错误。

MovieViewModel中的findMovieByGenre(String)无法应用 到()


protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    movieViewModel = ViewModelProviders.of(this). get(MovieViewModel.class);
    movieViewModel.findMovieByGenre("comedy").observe(this, new Observer<List<Movie>>() {
        @Override
        public void onChanged(@Nullable final List<Movie> movies) {

            Log.d("Movie", movies.get(num).getTitle());
            Log.d("Movie", movies.get(num).getDescription());
            Log.d("Movie", movies.get(num).getGenre());                
        }
    });
}

简而言之,我想匹配用户选择的流派,并将其与数据库中的流派条目相匹配,并返回匹配结果。

我的代码基于以下教程。如果您还有其他代码可以帮助我完成任务的材料,请将其传递给我们。

这里是当前代码的链接。 https://github.com/Shawn-Nichol/RoomExample

2 个答案:

答案 0 :(得分:0)

如果将MVVM体系结构与LiveData一起使用,请遵循此方法。

1 。在 MoviesActivity.java

中观察LiveData列表
final LiveData<List<MoviesData>> viewModelData = moviesViewModel.getMoviesByGenre("comedy");
    viewModelData.observe(this, new Observer<List<MoviesData>>() {
        @Override
        public void onChanged(List<MoviesData> moviesData) {
            //Handle the Movies List here.
        }
    });

2 。在 MoviesViewModel.java

public LiveData<List<NotificationData>> getMoviesByGenre(String genere) {
    MoviesRepository mRepository = new MoviesRepository(application);
    LiveData<List<MoviesData>> mMoviesData = mRepository.getMoviesByGenre(genere);
    return mMoviesData;
}

3 MoviesRepository.java

private MoviesDao mMoviesDao;

//Initialize.
AppDatabase db = AppDatabase.getAppDatabase(application);
mMoviesDao = db.moviesDao();



public LiveData<List<MoviesData>> getMoviesByGenre(String genere) {
    mMovies = mMoviesDao.findMovieByGenre(genere);
    return mMovies;
}

3 。在 MoviesDao

@Query("SELECT * FROM movie_table ORDER BY genre")
public LiveData<List<Movies> findMovieByGenre(String genre);

因此您可以在Activity类的Observe方法中观察查询结果。

答案 1 :(得分:-1)

要使用Room持久性库访问应用程序的数据,请使用数据访问对象或DAO。您可能必须在Android机房中使用DAO。

通过使用DAO类而不是查询生成器或直接查询访问数据库,您可以分离数据库体系结构的不同组件

this.state.fprActive