我已经建立了一个包含3列(标题,描述,流派)的房间数据库。我想用用户指定的类型(喜剧,恐怖等)查询流派列并返回结果。
我希望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);
}
}
我不确定我是否在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
如果您使用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类的“观察方法”中观察查询结果。
要使用Room持久性库访问应用程序的数据,您需要使用数据访问对象或DAO。你可能不得不在android机房使用DAO。
通过使用DAO类而不是查询构建器或直接查询来访问数据库,您可以分离数据库体系结构的不同组件
@Dao
public interface MyDao {
@Query("SELECT * FROM movie_table ORDER BY genre")
public ListMovies[] findMovieByGenre(String Genre);
}