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

问题描述 投票:3回答:2

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

DAO接口

我希望Query只检索类型与用户选择的类型匹配的条目。

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

存储库类

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

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,anonymous 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

android sql mvvm viewmodel android-room
2个回答
0
投票

如果您使用LiveData的MVVM架构,请遵循此方法。

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. movies repository.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类的“观察方法”中观察查询结果。


-1
投票

要使用Room持久性库访问应用程序的数据,您需要使用数据访问对象或DAO。你可能不得不在android机房使用DAO。

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

@Dao
public interface MyDao {
    @Query("SELECT * FROM movie_table ORDER BY genre")
    public ListMovies[] findMovieByGenre(String Genre);

}
© www.soinside.com 2019 - 2024. All rights reserved.