|
|
|
@ -44,7 +44,15 @@ public class SqlData {
|
|
|
|
|
DataColumns.ID, DataColumns.MIME_TYPE, DataColumns.CONTENT, DataColumns.DATA1,
|
|
|
|
|
DataColumns.DATA3
|
|
|
|
|
};
|
|
|
|
|
/*这是一个Java类,名称为SqlData,其中定义了一些静态变量和常量,用于在类内和类外引用。
|
|
|
|
|
|
|
|
|
|
第一行定义了一个名为TAG的静态常量字符串,用于在日志中标识该类。这个字符串的值是SqlData类的简单名称。
|
|
|
|
|
|
|
|
|
|
第二行定义了一个名为INVALID_ID的私有静态常量整数,用于表示无效的ID。该值被设置为-99999。
|
|
|
|
|
|
|
|
|
|
第三行定义了一个名为PROJECTION_DATA的公共静态常量字符串数组,用于定义一个查询所需返回的列。这些列包括DataColumns类中定义的ID、MIME_TYPE、CONTENT、DATA1和DATA3。
|
|
|
|
|
|
|
|
|
|
这些变量和常量都被声明为静态的,这意味着它们属于类本身,而不是类的实例。因此,它们可以在类的所有实例之间共享和访问。这些变量和常量的使用可以提高代码的可读性和可维护性,并避免在代码中多次重复相同的值。*/
|
|
|
|
|
public static final int DATA_ID_COLUMN = 0;
|
|
|
|
|
|
|
|
|
|
public static final int DATA_MIME_TYPE_COLUMN = 1;
|
|
|
|
@ -70,66 +78,96 @@ public class SqlData {
|
|
|
|
|
private String mDataContentData3;
|
|
|
|
|
|
|
|
|
|
private ContentValues mDiffDataValues;
|
|
|
|
|
/*这是一个Java类,名称为SqlData,其中定义了一些成员变量和常量,用于在类内存储和操作数据。
|
|
|
|
|
|
|
|
|
|
第一行定义了一个名为DATA_ID_COLUMN的公共静态常量整数,用于表示列索引中的数据ID列。
|
|
|
|
|
|
|
|
|
|
第二行定义了一个名为DATA_MIME_TYPE_COLUMN的公共静态常量整数,用于表示列索引中的MIME类型列。
|
|
|
|
|
|
|
|
|
|
第三行定义了一个名为DATA_CONTENT_COLUMN的公共静态常量整数,用于表示列索引中的内容列。
|
|
|
|
|
|
|
|
|
|
第四行定义了一个名为DATA_CONTENT_DATA_1_COLUMN的公共静态常量整数,用于表示列索引中的DATA1列。
|
|
|
|
|
|
|
|
|
|
第五行定义了一个名为DATA_CONTENT_DATA_3_COLUMN的公共静态常量整数,用于表示列索引中的DATA3列。
|
|
|
|
|
|
|
|
|
|
接下来的几行定义了该类的一些成员变量,包括ContentResolver类型的mContentResolver、boolean类型的mIsCreate、long类型的mDataId、String类型的mDataMimeType、String类型的mDataContent、long类型的mDataContentData1、String类型的mDataContentData3和ContentValues类型的mDiffDataValues。这些变量表示了该类的不同数据属性。
|
|
|
|
|
|
|
|
|
|
其中,ContentValues是一个键值对的集合,用于在Android应用中存储和操作数据。在该类中,mDiffDataValues被用于存储该对象的数据属性的差异,即该对象已更改但尚未提交到数据库中的值。*/
|
|
|
|
|
// 构造函数用于初始化一个SqlData对象的实例
|
|
|
|
|
public SqlData(Context context) {
|
|
|
|
|
mContentResolver = context.getContentResolver();
|
|
|
|
|
mIsCreate = true;
|
|
|
|
|
mDataId = INVALID_ID;
|
|
|
|
|
mDataMimeType = DataConstants.NOTE;
|
|
|
|
|
mDataContent = "";
|
|
|
|
|
mDataContentData1 = 0;
|
|
|
|
|
mDataContentData3 = "";
|
|
|
|
|
mDiffDataValues = new ContentValues();
|
|
|
|
|
mContentResolver = context.getContentResolver();// 获取ContentResolver对象,用于访问ContentProvider中的数据
|
|
|
|
|
mIsCreate = true;// 初始化数据的创建状态
|
|
|
|
|
mDataId = INVALID_ID; // 初始化数据的ID值
|
|
|
|
|
mDataMimeType = DataConstants.NOTE;// 初始化数据的MIME类型为NOTE
|
|
|
|
|
mDataContent = ""; // 初始化数据的内容为空字符串
|
|
|
|
|
mDataContentData1 = 0; // 初始化数据的数据内容Data1为0
|
|
|
|
|
mDataContentData3 = "";// 初始化数据的数据内容Data3为空字符串
|
|
|
|
|
mDiffDataValues = new ContentValues();// 初始化差异数据的ContentValues对象,用于保存数据的不同之处
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 定义SqlData类,该类用于处理数据库中的数据
|
|
|
|
|
public SqlData(Context context, Cursor c) {
|
|
|
|
|
// 获取ContentResolver对象
|
|
|
|
|
mContentResolver = context.getContentResolver();
|
|
|
|
|
// 设置初始状态为非创建状态
|
|
|
|
|
mIsCreate = false;
|
|
|
|
|
// 从Cursor对象中读取数据,并将数据加载到
|
|
|
|
|
loadFromCursor(c);
|
|
|
|
|
// 创建一个新的ContentValues对象,用于存储数据的差异
|
|
|
|
|
mDiffDataValues = new ContentValues();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*该构造函数主要是用于初始化SqlData对象,并且在初始化过程中从Cursor对象中读取数据,同时创建一个新的ContentValues对象,以备后续存储数据的差异。*/
|
|
|
|
|
/*定义了一个私有方法loadFromCursor,该方法接收一个Cursor对象作为参数,并且在该方法中从Cursor对象中读取数据,将这些数据加载到SqlData对象中。*/
|
|
|
|
|
// 从Cursor对象中读取数据,并将数据加载到SqlData对象中
|
|
|
|
|
private void loadFromCursor(Cursor c) {
|
|
|
|
|
// 从Cursor对象中读取数据id
|
|
|
|
|
mDataId = c.getLong(DATA_ID_COLUMN);
|
|
|
|
|
// 从Cursor对象中读取数据类型
|
|
|
|
|
mDataMimeType = c.getString(DATA_MIME_TYPE_COLUMN);
|
|
|
|
|
// 从Cursor对象中读取数据内容
|
|
|
|
|
mDataContent = c.getString(DATA_CONTENT_COLUMN);
|
|
|
|
|
// 从Cursor对象中读取数据内容的第一个数据项
|
|
|
|
|
mDataContentData1 = c.getLong(DATA_CONTENT_DATA_1_COLUMN);
|
|
|
|
|
// 从Cursor对象中读取数据内容的第三个数据项
|
|
|
|
|
mDataContentData3 = c.getString(DATA_CONTENT_DATA_3_COLUMN);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void setContent(JSONObject js) throws JSONException {
|
|
|
|
|
long dataId = js.has(DataColumns.ID) ? js.getLong(DataColumns.ID) : INVALID_ID;
|
|
|
|
|
/*该方法主要是用于从Cursor对象中读取数据,并将这些数据加载到SqlData对象的相关成员变量中。其中,数据的读取顺序和类型需要与Cursor对象中的列名一一对应。*/
|
|
|
|
|
public void setContent(JSONObject js) throws JSONException {// 设置SqlData对象的内容
|
|
|
|
|
long dataId = js.has(DataColumns.ID) ? js.getLong(DataColumns.ID) : INVALID_ID;// 从JSONObject对象中获取数据id
|
|
|
|
|
if (mIsCreate || mDataId != dataId) {
|
|
|
|
|
mDiffDataValues.put(DataColumns.ID, dataId);
|
|
|
|
|
}
|
|
|
|
|
mDataId = dataId;
|
|
|
|
|
mDataId = dataId; // 如果当前SqlData对象是创建状态,或者数据id与当前对象的数据id不同,将数据id加入到差异数据值对象中
|
|
|
|
|
|
|
|
|
|
//setContent方法的主要部分,用于设置SqlData对象的各个成员变量值,并且在设置过程中检查差异数据。
|
|
|
|
|
String dataMimeType = js.has(DataColumns.MIME_TYPE) ? js.getString(DataColumns.MIME_TYPE)
|
|
|
|
|
: DataConstants.NOTE;
|
|
|
|
|
if (mIsCreate || !mDataMimeType.equals(dataMimeType)) {
|
|
|
|
|
mDiffDataValues.put(DataColumns.MIME_TYPE, dataMimeType);
|
|
|
|
|
}
|
|
|
|
|
mDataMimeType = dataMimeType;
|
|
|
|
|
|
|
|
|
|
// 从JSONObject对象中获取数据类型,并将其设置为SqlData对象的数据类型
|
|
|
|
|
String dataContent = js.has(DataColumns.CONTENT) ? js.getString(DataColumns.CONTENT) : "";
|
|
|
|
|
if (mIsCreate || !mDataContent.equals(dataContent)) {
|
|
|
|
|
mDiffDataValues.put(DataColumns.CONTENT, dataContent);
|
|
|
|
|
}
|
|
|
|
|
mDataContent = dataContent;
|
|
|
|
|
|
|
|
|
|
// 从JSONObject对象中获取数据内容的第一个数据项,并将其设置为SqlData对象的数据内容的第一个数据项
|
|
|
|
|
long dataContentData1 = js.has(DataColumns.DATA1) ? js.getLong(DataColumns.DATA1) : 0;
|
|
|
|
|
if (mIsCreate || mDataContentData1 != dataContentData1) {
|
|
|
|
|
mDiffDataValues.put(DataColumns.DATA1, dataContentData1);
|
|
|
|
|
}
|
|
|
|
|
mDataContentData1 = dataContentData1;
|
|
|
|
|
|
|
|
|
|
// 从JSONObject对象中获取数据内容的第三个数据项,并将其设置为SqlData对象的数据内容的第三个数据项
|
|
|
|
|
String dataContentData3 = js.has(DataColumns.DATA3) ? js.getString(DataColumns.DATA3) : "";
|
|
|
|
|
if (mIsCreate || !mDataContentData3.equals(dataContentData3)) {
|
|
|
|
|
mDiffDataValues.put(DataColumns.DATA3, dataContentData3);
|
|
|
|
|
}
|
|
|
|
|
mDataContentData3 = dataContentData3;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*该代码段主要是根据JSONObject对象中的数据,设置SqlData对象的相应成员变量,并且在设置过程中检查差异数据。
|
|
|
|
|
其中,如果当前SqlData对象是创建状态,或者相应成员变量的值与JSONObject对象中的值不同,就将相应的数据加入到差异数据值对象中。
|
|
|
|
|
这些差异数据值将在后续的操作中被用于更新数据库中的数据。*/
|
|
|
|
|
public JSONObject getContent() throws JSONException {
|
|
|
|
|
if (mIsCreate) {
|
|
|
|
|
Log.e(TAG, "it seems that we haven't created this in database yet");
|
|
|
|
@ -143,6 +181,11 @@ public class SqlData {
|
|
|
|
|
js.put(DataColumns.DATA3, mDataContentData3);
|
|
|
|
|
return js;
|
|
|
|
|
}
|
|
|
|
|
/*这段代码定义了一个名为getContent()的方法,它返回一个JSONObject对象。
|
|
|
|
|
该方法可能会抛出一个JSONException异常,因此在调用该方法时需要处理该异常。
|
|
|
|
|
方法体内的第一条语句检查一个名为mIsCreate的 boolean 类型的成员变量是否为 true,如果是,则输出一个错误日志并返回 null。否则,方法会创建一个新的JSONObject对象,并向它添加一些键值对,这些键值对是由mDataId、mDataMimeType、mDataContent、mDataContentData1和mDataContentData3这些成员变量组成的。
|
|
|
|
|
最后,该方法返回一个JSONObject对象,其中包含了这些成员变量的值。*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public void commit(long noteId, boolean validateVersion, long version) {
|
|
|
|
|
|
|
|
|
@ -182,8 +225,21 @@ public class SqlData {
|
|
|
|
|
mDiffDataValues.clear();
|
|
|
|
|
mIsCreate = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*这段代码定义了一个名为commit()的方法,用于将已经修改的数据保存到数据库中。
|
|
|
|
|
方法接受三个参数:noteId为 long 类型,表示当前笔记的 ID;
|
|
|
|
|
validateVersion为 boolean 类型,表示是否需要验证版本;
|
|
|
|
|
version为 long 类型,表示当前笔记的版本。
|
|
|
|
|
方法体内的第一条语句检查一个名为mIsCreate的boolean类型的成员变量是否为true,如果是,则表示当前是创建一个新的数据,需要将数据插入到数据库中。
|
|
|
|
|
如果mDiffDataValues中包含 DataColumns.ID 这个键值对,表明该成员变量的值已经被赋值,需要将其移除,因为它是自增的主键,不应该由用户指定。
|
|
|
|
|
接下来,将 DataColumns.NOTE_ID 对应的值设置为noteId,并将mDiffDataValues插入到Notes.CONTENT_DATA_URI中获取Uri对象,然后Uri对象中获取新的数据的 ID 并设置给成员变量mDataId。
|
|
|
|
|
如果获取 ID 失败,则记录错误日志并抛出一个ActionFailureException异常。
|
|
|
|
|
如果mIsCreate的值为 false,则表示需要更新数据库中的数据。
|
|
|
|
|
如果mDiffDataValues中有数据,则调用mContentResolver.update()方法对数据库进行更新。
|
|
|
|
|
如果validateVersion的值为 false,则直接更新数据,否则需要先验证版本。验证版本的过程是通过查询NoteColumns.VERSION等于version且NoteColumns.ID等于的noteId
|
|
|
|
|
无论是插入数据还是更新数据,都需要清空mDiffDataValues的内容并将mIsCreate设为 false,表示数据已经提交保存到数据库中。*/
|
|
|
|
|
public long getId() {
|
|
|
|
|
return mDataId;
|
|
|
|
|
}
|
|
|
|
|
}//定义了一个名为getId()的方法,返回一个long类型的值,表示当前笔记的ID。
|
|
|
|
|
//直接返回成员变量mDataId,因此不会引发任何异常。
|
|
|
|
|
}
|
|
|
|
|
6
|