[英]how to listen for SQLite database changes in android
我在 android 中使用 SQLite 数据库并想监听任何数据库更改。 我怎样才能做到这一点?
感谢所有未来的帮助!
事实上,SQLite 提供了这样的功能: SQLite Data Change Notification Callbacks
不过,如何在 Android 中使用它是另一回事。
SQLite 不提供任何更改监听器功能; 你必须自己监控它。 实现此目的的最简单方法是在您修改数据库时发送广播(甚至更好,本地广播)。 一些数据库库已经提供了与此类似的功能 - 查看GreenDAO 。
假设您有一个类来处理您的 android 应用程序中的查询,我们需要使数据库方法可观察。 而且我们还需要一些听众来观察上述可观察的。 让我们让数据库处理程序observable
:
让我们制作可观察的界面:
public interface DatabaseObservable {
//register the observer with this method
void registerDbObserver(DatabaseObserver databaseObserver);
//unregister the observer with this method
void removeDbObserver(DatabaseObserver databaseObserver);
//call this method upon database change
void notifyDbChanged();
}
现在在你的数据库类中implement
observable
public class LocalStorageDb extends SQLiteOpenHelper implements DatabaseObservable {
LocalStorageDb lDb;
//make it Singleton
public static synchronized LocalStorageDB getInstance(Context context) {
if (mlLocalQuickChatDB == null) {
mlLocalQuickChatDB = new LocalStorageDB(context.getApplicationContext());
}
return mlLocalQuickChatDB;
}
//there are some methods to do some queries
public void createContact(Foo foo, Bar bar){
//some queries here
//call the Observable Method to let know the observers that it has changed
onDatabaseChanged();
}
//now override the DatabaseObservable method which is responsible to notify the listeners
@Override
public void onDatabaseChanged() {
for (DatabaseObserver databaseObserver:observerArrayList){
if (databaseObserver!= null){
databaseObserver.onDatabaseChanged();
}}
}
//also you need functions to **register** or **unregister** the observers:
@Override
public void registerDbObserver(DatabaseObserver databaseObserver) {
if (!observerArrayList.contains(databaseObserver)){
observerArrayList.add(databaseObserver);
}
@Override
public void removeDbObserver(DatabaseObserver databaseObserver) {
observerArrayList.remove(databaseObserver);
}
那么我们需要一个observer
来观察变化:
public interface DatabaseObserver {
void onDatabaseChanged();
}
现在在您的活动或片段中,有一个获取更改的函数,例如getLocalContact
。 在片段上实现观察者,例如:
public class ExampleFragment extends Fragment implements DatabaseObserver {
LocalStorageDB localStorageDB;
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
localStorageDB = LocalStorageDB.getInstance();
}
@Override
public void onPause() {
super.onPause();
localStorageDB.removeObserver(this);
}
@Override
public void onResume() {
localStorageDB.registerObserver(this);
super.onResume();
}
public ExampleFragment() {
// Required empty public constructor
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
return inflater.inflate(R.layout.fragment_example, container, false);
}
@Override
public void onDatabaseChanged() {
getLocalContact();
}
private void getLocalContact(){
//function to fetch contacts from database
}
}
嗨,我想添加一个新的建议,以防使用 firebase。 您可以为用户消息创建一个新的 json 节点,并使用 On Data Change 来检测新的未读消息数量,然后在 onDatachange 中更新您的 ui。 这是聪明的还是远离主要思想?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.