日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

联系人存储ContactsProvider表分析

發布時間:2023/12/14 编程问答 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 联系人存储ContactsProvider表分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

ContactsProvider建表的都在

packages/providers/ContactsProvider/src/com/android/providers/contacts/ContactsDatabaseHelper.java

首先該文件中有個Tables接口,其中的常量定義了數據庫中大部分的表

public interface Tables {public static final String CONTACTS = "contacts"; //聯系人,由raw_contacts表聚合而成public static final String DELETED_CONTACTS = "deleted_contacts"; //標記要刪除的聯系人public static final String RAW_CONTACTS = "raw_contacts"; //聯系人的原始數據,同一個聯系人可能對應多個raw_contactspublic static final String STREAM_ITEMS = "stream_items"; //IM信息public static final String STREAM_ITEM_PHOTOS = "stream_item_photos"; //IM信息相關頭像public static final String PHOTO_FILES = "photo_files"; //照片public static final String PACKAGES = "packages"; //包名public static final String MIMETYPES = "mimetypes"; //mime類型public static final String PHONE_LOOKUP = "phone_lookup"; //依據號碼查聯系人public static final String NAME_LOOKUP = "name_lookup"; //依據名字查聯系人public static final String AGGREGATION_EXCEPTIONS = "agg_exceptions"; //合并聯系人規則public static final String SETTINGS = "settings"; //設置public static final String DATA = "data"; //聯系人最原始的數據,每一個row可以是號碼、地址、名字等等public static final String GROUPS = "groups"; //聯系人組public static final String PRESENCE = "presence"; //IM在線狀態public static final String AGGREGATED_PRESENCE = "agg_presence"; //IM在線狀態,聚合使用public static final String NICKNAME_LOOKUP = "nickname_lookup"; //昵稱查找public static final String CALLS = "calls"; //通話記錄public static final String STATUS_UPDATES = "status_updates";//聊天程序狀態public static final String PROPERTIES = "properties"; //屬性public static final String ACCOUNTS = "accounts"; //賬戶public static final String VISIBLE_CONTACTS = "visible_contacts"; //標記可見聯系人public static final String DIRECTORIES = "directories";//通訊錄public static final String DEFAULT_DIRECTORY = "default_directory";//默認通訊錄public static final String SEARCH_INDEX = "search_index"; //搜索public static final String VOICEMAIL_STATUS = "voicemail_status";//語音郵箱public static final String PRE_AUTHORIZED_URIS = "pre_authorized_uris";//申請權限...public static final String DATA_USAGE_STAT = "data_usage_stat"; //data使用統計...public static final String DIALER_SEARCH = "dialer_search";//撥號盤搜索表public static final String CONFERENCE_CALLS = "conference_calls"; //會議組通話}

PROPERTIES

屬性表

db.execSQL("CREATE TABLE " + Tables.PROPERTIES + " (" +PropertiesColumns.PROPERTY_KEY + " TEXT PRIMARY KEY, " + //keyPropertiesColumns.PROPERTY_VALUE + " TEXT " + //value");");只有兩個字段,key值有:

public interface DbProperties {String DIRECTORY_SCAN_COMPLETE = "directoryScanComplete"; //Directory掃描完畢String AGGREGATION_ALGORITHM = "aggregation_v2";//聯系人聚合算法String KNOWN_ACCOUNTS = "known_accounts"; //系統所有賬號String ICU_VERSION = "icu_version"; //icu版本String LOCALE = "locale"; //所在區域String DATABASE_TIME_CREATED = "database_time_created"; //數據庫創建時間String CALL_LOG_LAST_SYNCED = "call_log_last_synced"; //最后一次同步通話記錄的時間}

ICU的解釋見點擊打開鏈接

ICU(International Component for Unicode) 是 IBM 與開源組織合作研究 , 基于 "IBM 公共許可證 " 的用于支持軟件國際化的開源項目。 ICU 實現了對數字、日期、貨幣等提供國際化支持,提供了強大的 BIDI 算法,對阿拉伯語和希伯來語等 BiDi 語言提供了完善的支持。 ICU 分為 ICU4J 和 ICU4C,分別對應 Java 和 c/c++ 平臺。 ICU4J 被 Sun 的 JDK1.1 采用并隨 JDK 版本更新。最新的 ICU4J 庫可以從 http://icu-project.org/ 網站上下載。

ACCOUNTS?

賬戶表
db.execSQL("CREATE TABLE " + Tables.ACCOUNTS + " (" + AccountsColumns._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +AccountsColumns.ACCOUNT_NAME + " TEXT, " + //賬戶名稱AccountsColumns.ACCOUNT_TYPE + " TEXT, " + //賬戶類型AccountsColumns.DATA_SET + " TEXT" + //所屬數據集");");

賬戶類型在ContactsProvider2中針對手機定義了5個,一個本地賬戶(最常用的賬戶)和4個卡賬戶.

public static final String ACCOUNT_TYPE_LOCAL_PHONE = "Local Phone Account";public static final String ACCOUNT_TYPE_SIM = "SIM Account";public static final String ACCOUNT_TYPE_USIM = "USIM Account";public static final String ACCOUNT_TYPE_UIM = "UIM Account";public static final String ACCOUNT_TYPE_CSIM = "CSIM Account";data_set 是區分不同同步源的,因為同一個賬戶的數據是可以被多個數據源備份的。

CONTACTS

聯系人表 db.execSQL("CREATE TABLE " + Tables.CONTACTS + " (" +BaseColumns._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +Contacts.NAME_RAW_CONTACT_ID + " INTEGER REFERENCES raw_contacts(_id)," + //對應raw_contacts表中id,用于顯示名字Contacts.PHOTO_ID + " INTEGER REFERENCES data(_id)," + //data表中photo相關row的idContacts.PHOTO_FILE_ID + " INTEGER REFERENCES photo_files(_id)," + //對應photo_files表中idContacts.CUSTOM_RINGTONE + " TEXT," + //來電鈴聲Contacts.SEND_TO_VOICEMAIL + " INTEGER NOT NULL DEFAULT 0," + //標記該聯系人來電是否直接轉接到語音郵箱Contacts.TIMES_CONTACTED + " INTEGER NOT NULL DEFAULT 0," + //聯系次數,如撥號會更新該值。Contacts.LAST_TIME_CONTACTED + " INTEGER," + //最后一次聯系的時間,如電話、短信等Contacts.STARRED + " INTEGER NOT NULL DEFAULT 0," + //是否為星標聯系人Contacts.PINNED + " INTEGER NOT NULL DEFAULT " + PinnedPositions.UNPINNED + "," + //標記在聯系人列表中是否訂住,訂住后滑動列表不會消失Contacts.HAS_PHONE_NUMBER + " INTEGER NOT NULL DEFAULT 0," + //是否有號碼Contacts.LOOKUP_KEY + " TEXT," + //lookup_key, 方便在聚合的情況下找到聯系人,因為聚合的時候有可能id無效ContactsColumns.LAST_STATUS_UPDATE_ID + " INTEGER REFERENCES data(_id)," + //最后更新的對應data表中的idContacts.CONTACT_LAST_UPDATED_TIMESTAMP + " INTEGER," + //最后更新時間Contacts.SEND_TO_VOICEMAIL_VT + " INTEGER NOT NULL DEFAULT 0," + //add by MTK 類似SEND_TO_VOICEMAIL,視頻通話相關Contacts.SEND_TO_VOICEMAIL_SIP + " INTEGER NOT NULL DEFAULT 0," + //add by MTK 類似SEND_TO_VOICEMAIL,sip通話相關Contacts.INDICATE_PHONE_SIM + " INTEGER NOT NULL DEFAULT -1," + //add by MTK,是否為卡聯系人Contacts.INDEX_IN_SIM + " INTEGER NOT NULL DEFAULT -1," + //add by MTK 在sim卡中的索引Contacts.FILTER + " INTEGER NOT NULL DEFAULT 0," + //add by MTK 用于標記該聯系人是否可以顯示桌面widgetContacts.IS_SDN_CONTACT + " INTEGER NOT NULL DEFAULT 0" + // add by MTK 是否為sdn聯系人");");表中的每一個row都代表一個聯系人,這一個聯系人可能在多個賬戶下都有,對應多個RawContact。例如本地賬戶、微信和qq都對應一個手機號碼,聚合后是一個Contact,有3個RawContact。 SDN (系統撥叫號碼) 網絡服務撥號。固化的用戶不能編輯。見點擊打開鏈接

DELETED_CONTACTS

刪除聯系人表

db.execSQL("CREATE TABLE " + ContactsDatabaseHelper.Tables.DELETED_CONTACTS + " (" +ContactsContract.DeletedContacts.CONTACT_ID + " INTEGER PRIMARY KEY," + //刪除的聯系人idContactsContract.DeletedContacts.CONTACT_DELETED_TIMESTAMP + //刪除時間" INTEGER NOT NULL default 0"+ ");");刪除聯系人時候并不是直接刪除,而是先標記刪除的聯系人

RAW_CONTACTS?

源聯系人表

db.execSQL("CREATE TABLE " + Tables.RAW_CONTACTS + " (" +RawContacts._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +RawContactsColumns.ACCOUNT_ID + " INTEGER REFERENCES " + //賬戶id,對應于account表中的idTables.ACCOUNTS + "(" + AccountsColumns._ID + ")," +RawContacts.SOURCE_ID + " TEXT," + //源賬戶id,例如當前是手機賬戶id,但是源id是sim卡賬戶,表示該聯系人是從sim卡導入的RawContacts.BACKUP_ID + " TEXT," + //備份源id,唯一的RawContacts.RAW_CONTACT_IS_READ_ONLY + " INTEGER NOT NULL DEFAULT 0," + //是否為只讀RawContacts.VERSION + " INTEGER NOT NULL DEFAULT 1," + //版本號,每次更新后都會有變化RawContacts.DIRTY + " INTEGER NOT NULL DEFAULT 0," + //VERSION有變化,表示要同步數據RawContacts.DELETED + " INTEGER NOT NULL DEFAULT 0," + //標記該聯系人要刪除,刪除聚合聯系人和同步server中的數據,最后再刪除數據RawContacts.CONTACT_ID + " INTEGER REFERENCES contacts(_id)," + //對應Contacts表中的idRawContacts.AGGREGATION_MODE + " INTEGER NOT NULL DEFAULT " + //聚合模式,解釋見后文RawContacts.AGGREGATION_MODE_DEFAULT + "," +RawContactsColumns.AGGREGATION_NEEDED + " INTEGER NOT NULL DEFAULT 1," + //標記是否要聚合RawContacts.CUSTOM_RINGTONE + " TEXT," + //鈴聲RawContacts.SEND_TO_VOICEMAIL + " INTEGER NOT NULL DEFAULT 0," + //標記該聯系人來電后是否要直接轉到語音郵箱RawContacts.TIMES_CONTACTED + " INTEGER NOT NULL DEFAULT 0," + //聯系次數RawContacts.LAST_TIME_CONTACTED + " INTEGER," + //最后聯系時間點RawContacts.STARRED + " INTEGER NOT NULL DEFAULT 0," + //是否為星標聯系人RawContacts.PINNED + " INTEGER NOT NULL DEFAULT " + PinnedPositions.UNPINNED + //是否在列表中“訂住”"," + RawContacts.DISPLAY_NAME_PRIMARY + " TEXT," + //名字,名在前,RawContacts.DISPLAY_NAME_ALTERNATIVE + " TEXT," + //名字,姓在前RawContacts.DISPLAY_NAME_SOURCE + " INTEGER NOT NULL DEFAULT " + //名字源,解釋見后文DisplayNameSources.UNDEFINED + "," +RawContacts.PHONETIC_NAME + " TEXT," + //名字對應的語音序列,如漢字對應的拼音RawContacts.PHONETIC_NAME_STYLE + " TEXT," + //語音序列類型,解釋見后文RawContacts.SORT_KEY_PRIMARY + " TEXT COLLATE " + //排序字段ContactsProvider2.PHONEBOOK_COLLATOR_NAME + "," +RawContactsColumns.PHONEBOOK_LABEL_PRIMARY + " TEXT," + //名字首對應首字母,這個是為了歸類名字到26個字母。RawContactsColumns.PHONEBOOK_BUCKET_PRIMARY + " INTEGER," + //名字對應首字母對應的序號,如字母D對應4,RawContacts.SORT_KEY_ALTERNATIVE + " TEXT COLLATE " + //姓在前名字排序字段ContactsProvider2.PHONEBOOK_COLLATOR_NAME + "," +RawContactsColumns.PHONEBOOK_LABEL_ALTERNATIVE + " TEXT," + //類似PHONEBOOK_LABEL_PRIMARYRawContactsColumns.PHONEBOOK_BUCKET_ALTERNATIVE + " INTEGER," + //類似PHONEBOOK_BUCKET_PRIMARYRawContactsColumns.NAME_VERIFIED_OBSOLETE + " INTEGER NOT NULL DEFAULT 0," + //這個字段目前已不用RawContacts.SYNC1 + " TEXT, " + //同步要用的字段RawContacts.SYNC2 + " TEXT, " +RawContacts.SYNC3 + " TEXT, " +RawContacts.SYNC4 + " TEXT, " +RawContacts.TIMESTAMP + " INTEGER," + //add by MTK ,VERSION變化時間點RawContacts.SEND_TO_VOICEMAIL_VT + " INTEGER NOT NULL DEFAULT 0," + // add by MTK,后續同Contacts表中解釋RawContacts.SEND_TO_VOICEMAIL_SIP + " INTEGER NOT NULL DEFAULT 0," + // add by MTKRawContacts.INDICATE_PHONE_SIM + " INTEGER NOT NULL DEFAULT -1," + //add by MTKRawContacts.INDEX_IN_SIM + " INTEGER NOT NULL DEFAULT -1," + //add by MTKRawContacts.IS_SDN_CONTACT + " INTEGER NOT NULL DEFAULT 0" + // add by MTK");");這個表中的每一個row對應于一個賬戶的數據,如果用戶只使用一個本地手機賬戶的話,實際上就是一個RawContact對應一個Contact。

AGGREGATION_MODE ?

public static final int AGGREGATION_MODE_DEFAULT = 0; //不覆蓋之前設置的模式public static final int AGGREGATION_MODE_IMMEDIATE = 1; //插入或者更新時馬上合并public static final int AGGREGATION_MODE_SUSPENDED = 2; //暫緩合并,例如批量插入時先不合并,插入完畢后再統一合并public static final int AGGREGATION_MODE_DISABLED = 3; //不合并

DISPLAY_NAME_SOURCE

public interface DisplayNameSources {public static final int UNDEFINED = 0; public static final int EMAIL = 10; //電子郵件public static final int PHONE = 20; //電話public static final int ORGANIZATION = 30; //公司public static final int NICKNAME = 35; //昵稱public static final int STRUCTURED_NAME = 40; //名字}PHONETIC_NAME_STYLE?

public interface PhoneticNameStyle {public static final int UNDEFINED = 0;public static final int PINYIN = 3; //中文public static final int JAPANESE = 4; //日文public static final int KOREAN = 5; //朝鮮文}

STREAM_ITEMS

steam item表 db.execSQL("CREATE TABLE " + Tables.STREAM_ITEMS + " (" +StreamItems._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +StreamItems.RAW_CONTACT_ID + " INTEGER NOT NULL, " + //對應的RawContact IdStreamItems.RES_PACKAGE + " TEXT, " + //相關程序包名StreamItems.RES_ICON + " TEXT, " + //相關程序的圖標StreamItems.RES_LABEL + " TEXT, " + //相關程序名,例如“Google Talk”StreamItems.TEXT + " TEXT, " + //信息字符串,例如朋友圈的內容StreamItems.TIMESTAMP + " INTEGER NOT NULL, " + //時間戳StreamItems.COMMENTS + " TEXT, " + //摘要信息,例如Text已被幾人讀過StreamItems.SYNC1 + " TEXT, " + //同步需要的字段StreamItems.SYNC2 + " TEXT, " +StreamItems.SYNC3 + " TEXT, " +StreamItems.SYNC4 + " TEXT, " +"FOREIGN KEY(" + StreamItems.RAW_CONTACT_ID + ") REFERENCES " +Tables.RAW_CONTACTS + "(" + RawContacts._ID + "));");這個表是Deprecated,不會使用。從注釋看是為聊天工具準備的,記錄聊天工具最新的信息。

STREAM_ITEM_PHOTOS

steam photo表 db.execSQL("CREATE TABLE " + Tables.STREAM_ITEM_PHOTOS + " (" +StreamItemPhotos._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +StreamItemPhotos.STREAM_ITEM_ID + " INTEGER NOT NULL, " + //對應的stream item idStreamItemPhotos.SORT_INDEX + " INTEGER, " + //排序字段StreamItemPhotos.PHOTO_FILE_ID + " INTEGER NOT NULL, " + //頭像文件idStreamItemPhotos.SYNC1 + " TEXT, " +StreamItemPhotos.SYNC2 + " TEXT, " +StreamItemPhotos.SYNC3 + " TEXT, " +StreamItemPhotos.SYNC4 + " TEXT, " +"FOREIGN KEY(" + StreamItemPhotos.STREAM_ITEM_ID + ") REFERENCES " +Tables.STREAM_ITEMS + "(" + StreamItems._ID + "));");這個表是Deprecated,不會使用。記錄stream item中的頭像信息

PHOTO_FILES

頭像表 db.execSQL("CREATE TABLE " + Tables.PHOTO_FILES + " (" +PhotoFiles._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +PhotoFiles.HEIGHT + " INTEGER NOT NULL, " + //高PhotoFiles.WIDTH + " INTEGER NOT NULL, " + //寬PhotoFiles.FILESIZE + " INTEGER NOT NULL);"); //文件大小

PACKAGES

包名表 db.execSQL("CREATE TABLE " + Tables.PACKAGES + " (" +PackagesColumns._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +PackagesColumns.PACKAGE + " TEXT NOT NULL" + //包名");");id 和包名對照表,依據id獲取包名

MIMETYPES

mime類型表 db.execSQL("CREATE TABLE " + Tables.MIMETYPES + " (" +MimetypesColumns._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +MimetypesColumns.MIMETYPE + " TEXT NOT NULL" +");");百度百科:MIME(Multipurpose Internet Mail Extensions)多用途互聯網郵件擴展類型。它是一個互聯網標準,擴展了電子郵件標準.
這張表記錄了data所有對象的類型,依據該類型可以區分每個row數據是什么。這些類型全部在ContactsContract中已CONTENT_ITEM_TYPE定義,例如Phone中的: /** MIME type used when storing this in data table. */public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/phone_v2"; 標記該類型數據是電話號碼 StructuredName中 /** MIME type used when storing this in data table. */public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/name";標記該類型數據是名字

DATA?

數據表 db.execSQL("CREATE TABLE " + Tables.DATA + " (" +Data._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +DataColumns.PACKAGE_ID + " INTEGER REFERENCES package(_id)," + //插入數據的程序包名idDataColumns.MIMETYPE_ID + " INTEGER REFERENCES mimetype(_id) NOT NULL," + //mime類型idData.RAW_CONTACT_ID + " INTEGER REFERENCES raw_contacts(_id) NOT NULL," + //所屬的RawContact IdData.HASH_ID + " TEXT," + //哈希值,用于恢復和備份數據Data.IS_READ_ONLY + " INTEGER NOT NULL DEFAULT 0," + //是否只讀Data.IS_PRIMARY + " INTEGER NOT NULL DEFAULT 0," + //標記為聯系人的主要屬性Data.IS_SUPER_PRIMARY + " INTEGER NOT NULL DEFAULT 0," + //標記為聯系人聚合后的主要屬性,IS_SUPER_PRIMARY的前提是IS_PRIMARY為trueData.DATA_VERSION + " INTEGER NOT NULL DEFAULT 0," + //版本號Data.DATA1 + " TEXT," + //數據Data.DATA2 + " TEXT," +Data.DATA3 + " TEXT," +Data.DATA4 + " TEXT," +Data.DATA5 + " TEXT," +Data.DATA6 + " TEXT," +Data.DATA7 + " TEXT," +Data.DATA8 + " TEXT," +Data.DATA9 + " TEXT," +Data.DATA10 + " TEXT," +Data.DATA11 + " TEXT," +Data.DATA12 + " TEXT," +Data.DATA13 + " TEXT," +Data.DATA14 + " TEXT," +Data.DATA15 + " TEXT," +Data.SYNC1 + " TEXT, " + //同步需要的字段Data.SYNC2 + " TEXT, " +Data.SYNC3 + " TEXT, " +Data.SYNC4 + " TEXT, " +Data.CARRIER_PRESENCE + " INTEGER NOT NULL DEFAULT 0," + //目前只有一個可選值,標記是否可以視頻通話Data.SIM_ASSOCIATION_ID + " INTEGER NOT NULL DEFAULT -1, " + //add by MTK 卡聯系人相關的sub_idData.IS_ADDITIONAL_NUMBER + " INTEGER NOT NULL DEFAULT 0 " + //add by MTK 作用未知");"); DATA1~DATA15依據mime類型的不同有不同的意義,例如mime是名字:
private interface RawContactNameQuery {...public static final int DATA1 = 2; //全名public static final int GIVEN_NAME = 3; // data2 名public static final int FAMILY_NAME = 4; // data3 姓public static final int PREFIX = 5; // data4 前綴public static final int TITLE = 5; // data4 頭銜public static final int MIDDLE_NAME = 6; // data5 中間名public static final int SUFFIX = 7; // data6 后綴public static final int PHONETIC_GIVEN_NAME = 8; // data7 姓的語音字符序列public static final int PHONETIC_MIDDLE_NAME = 9; // data8 中間名語音字符序列public static final int ORGANIZATION_PHONETIC_NAME = 9; // data8 公司名語音字符序列public static final int PHONETIC_FAMILY_NAME = 10; // data9 姓語音字符序列public static final int FULL_NAME_STYLE = 11; // data10 名字類型,解釋如下public static final int ORGANIZATION_PHONETIC_NAME_STYLE = 11; // data10public static final int PHONETIC_NAME_STYLE = 12; // data11}PHONETIC_NAME_STYLE之前已介紹,FULL_NAME_STYLE 如下定義: public interface FullNameStyle {public static final int UNDEFINED = 0;public static final int WESTERN = 1;/*** Used if the name is written in Hanzi/Kanji/Hanja and we could not determine* which specific language it belongs to: Chinese, Japanese or Korean.*/public static final int CJK = 2;public static final int CHINESE = 3;public static final int JAPANESE = 4;public static final int KOREAN = 5;}

PHONE_LOOKUP?

號碼查找表 db.execSQL("CREATE TABLE " + Tables.PHONE_LOOKUP + " (" +PhoneLookupColumns.DATA_ID+ " INTEGER REFERENCES data(_id) NOT NULL," + //對應data表中的idPhoneLookupColumns.RAW_CONTACT_ID+ " INTEGER REFERENCES raw_contacts(_id) NOT NULL," + //對應raw_contacts表idPhoneLookupColumns.NORMALIZED_NUMBER + " TEXT NOT NULL," + //號碼PhoneLookupColumns.MIN_MATCH + " TEXT NOT NULL" + //最小匹配號碼");");依據號碼查找聯系人數據,可見從這個表查找聯系人id會少一個步驟。MIN_MATCH字段是號碼的倒序,且長度不會超過一定長度(默認是7位,國內是11位)。這個是為了號碼匹配,因為號碼匹配是從字符串右邊開始的,且達到一定位數就認為號碼匹配成功,例如+8613812345678和13812345678 是匹配的。

NAME_LOOKUP

名字查找表 db.execSQL("CREATE TABLE " + Tables.NAME_LOOKUP + " (" +NameLookupColumns.DATA_ID+ " INTEGER REFERENCES data(_id) NOT NULL," +NameLookupColumns.RAW_CONTACT_ID+ " INTEGER REFERENCES raw_contacts(_id) NOT NULL," +NameLookupColumns.NORMALIZED_NAME + " TEXT NOT NULL," +NameLookupColumns.NAME_TYPE + " INTEGER NOT NULL," +"PRIMARY KEY ("+ NameLookupColumns.DATA_ID + ", "+ NameLookupColumns.NORMALIZED_NAME + ", "+ NameLookupColumns.NAME_TYPE + ")" +");");按名字查找聯系人,其它字段同號碼查找表類似,其中NAME_TYPE public static final int NAME_EXACT = 0;//名字public static final int NAME_VARIANT = 1; //名字變體,就是token的所有順序public static final int NAME_COLLATION_KEY = 2; //為了排序public static final int NICKNAME = 3; //昵稱public static final int EMAIL_BASED_NICKNAME = 4; //郵箱地址名字插入的時候會生成這五種類型的數據到表中,前三中是基于名字的,后兩種是從數據庫表中查詢生成的。這里注意代碼中的NickName有兩種情況,NICKNAME類型對應的是Nickname.CONTENT_ITEM_TYPE類型的data表中的數據,而packages/providers/ContactsProvider/src/com/android/providers/contacts/aggregation/util/CommonNicknameCache.java中的NickName對應的是常用英文名的縮寫,如"Robert", "Bob" and "Rob"是一個意思,這部分的字符串替換是算在NAME_VARIANT類型中的

NICKNAME_LOOKUP

昵稱表 db.execSQL("CREATE TABLE " + Tables.NICKNAME_LOOKUP + " (" +NicknameLookupColumns.NAME + " TEXT," + //名字NicknameLookupColumns.CLUSTER + " TEXT" + //名字對應id");");這個是被framework中的資源初始化的
private void loadNicknameLookupTable(SQLiteDatabase db) {db.execSQL("DELETE FROM " + Tables.NICKNAME_LOOKUP);String[] strings = mContext.getResources().getStringArray(com.android.internal.R.array.common_nicknames);...}該字符串定義在frameworks/base/core/res/res/values-en-rUS/donottranslate-names.xml中 <string-array name="common_nicknames"><item>Abigail, Abbie</item><item>Abigail, Gail, Gayle</item><item>Abe, Abraham</item>...可以看出每行數據定義了等價的名字,同一行的名字有相同的id

GROUPS

群組表 db.execSQL("CREATE TABLE " + Tables.GROUPS + " (" +Groups._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +GroupsColumns.PACKAGE_ID + " INTEGER REFERENCES package(_id)," + //對應package表中的idGroupsColumns.ACCOUNT_ID + " INTEGER REFERENCES " + //對應account表中的idTables.ACCOUNTS + "(" + AccountsColumns._ID + ")," +Groups.SOURCE_ID + " TEXT," + //源賬戶idGroups.VERSION + " INTEGER NOT NULL DEFAULT 1," + //版本號Groups.DIRTY + " INTEGER NOT NULL DEFAULT 0," + //是否要同步Groups.TITLE + " TEXT," + //群組名Groups.TITLE_RES + " INTEGER," + //群組名資源idGroups.NOTES + " TEXT," + //備注Groups.SYSTEM_ID + " TEXT," + //系統群組id,對同步有重要意義,從代碼中看有系統id的GROUP_IS_READ_ONLY都會設置為1Groups.DELETED + " INTEGER NOT NULL DEFAULT 0," + //標記是否刪除Groups.GROUP_VISIBLE + " INTEGER NOT NULL DEFAULT 0," + //是否可見Groups.SHOULD_SYNC + " INTEGER NOT NULL DEFAULT 1," + //當SYNC_EVERYTHING設置為false的時候,是否同步Groups.AUTO_ADD + " INTEGER NOT NULL DEFAULT 0," + //新建聯系人后是否自動添加到該群組Groups.FAVORITES + " INTEGER NOT NULL DEFAULT 0," + //星標聯系人是否自動添加到該群組Groups.GROUP_IS_READ_ONLY + " INTEGER NOT NULL DEFAULT 0," + //是否只讀Groups.SYNC1 + " TEXT, " + //同步字段Groups.SYNC2 + " TEXT, " +Groups.SYNC3 + " TEXT, " +Groups.SYNC4 + " TEXT " +");");

AGGREGATION_EXCEPTIONS

聚合規則表 db.execSQL("CREATE TABLE IF NOT EXISTS " + Tables.AGGREGATION_EXCEPTIONS + " (" +AggregationExceptionColumns._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +AggregationExceptions.TYPE + " INTEGER NOT NULL, " +AggregationExceptions.RAW_CONTACT_ID1+ " INTEGER REFERENCES raw_contacts(_id), " +AggregationExceptions.RAW_CONTACT_ID2+ " INTEGER REFERENCES raw_contacts(_id)" +");");類型有三種: public static final int TYPE_AUTOMATIC = 0; //自動聚合public static final int TYPE_KEEP_TOGETHER = 1; //聚合public static final int TYPE_KEEP_SEPARATE = 2; //不聚合另外兩個字段是兩個RawContact Id. 這個表可以添加聯系人聚合的規則,聯系人聚合時會參照這個規則。這個表的最大用處是手動合并聯系人。

SETTINGS

設置表 db.execSQL("CREATE TABLE IF NOT EXISTS " + Tables.SETTINGS + " (" +Settings.ACCOUNT_NAME + " STRING NOT NULL," + //賬戶名稱Settings.ACCOUNT_TYPE + " STRING NOT NULL," + //賬戶類型Settings.DATA_SET + " STRING," + //標記同步源,一個數據庫可備份到多處Settings.UNGROUPED_VISIBLE + " INTEGER NOT NULL DEFAULT 0," + //不再群組內的聯系人是否可見Settings.SHOULD_SYNC + " INTEGER NOT NULL DEFAULT 1" + //是否啟用同步,這個是最高等級的開關");");

VISIBLE_CONTACTS

可見聯系人表 db.execSQL("CREATE TABLE " + Tables.VISIBLE_CONTACTS + " (" +Contacts._ID + " INTEGER PRIMARY KEY" +");");只有一個字段,可見聯系人的id

DEFAULT_DIRECTORY?

默認通訊錄表 db.execSQL("CREATE TABLE " + Tables.DEFAULT_DIRECTORY + " (" +Contacts._ID + " INTEGER PRIMARY KEY" +");");無賬戶和無群組的聯系人的id都會插入到這個表中

CALLS

見通話記錄

VOICEMAIL_STATUS

語音郵箱狀態表 db.execSQL("CREATE TABLE " + Tables.VOICEMAIL_STATUS + " (" +VoicemailContract.Status._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +VoicemailContract.Status.SOURCE_PACKAGE + " TEXT UNIQUE NOT NULL," + //VoicemailContract.Status.PHONE_ACCOUNT_COMPONENT_NAME + " TEXT," + //phone進程的包名VoicemailContract.Status.PHONE_ACCOUNT_ID + " TEXT," + //實際就是sim卡的subidVoicemailContract.Status.SETTINGS_URI + " TEXT," + //action view加上這個uri的intent可以拉起設置界面VoicemailContract.Status.VOICEMAIL_ACCESS_URI + " TEXT," + //獲取語音郵件VoicemailContract.Status.CONFIGURATION_STATE + " INTEGER," + //設置狀態,解釋見下VoicemailContract.Status.DATA_CHANNEL_STATE + " INTEGER," + //數據連接狀態VoicemailContract.Status.NOTIFICATION_CHANNEL_STATE + " INTEGER" + //通知連接狀態");");CONFIGURATION_STATE public static final int CONFIGURATION_STATE_OK = 0;public static final int CONFIGURATION_STATE_NOT_CONFIGURED = 1;public static final int CONFIGURATION_STATE_CAN_BE_CONFIGURED = 2;DATA_CHANNEL_STATE public static final int DATA_CHANNEL_STATE_OK = 0;public static final int DATA_CHANNEL_STATE_NO_CONNECTION = 1;NOTIFICATION_CHANNEL_STATE
public static final int NOTIFICATION_CHANNEL_STATE_OK = 0;public static final int NOTIFICATION_CHANNEL_STATE_NO_CONNECTION = 1;

STATUS_UPDATES?

狀態表 db.execSQL("CREATE TABLE " + Tables.STATUS_UPDATES + " (" +StatusUpdatesColumns.DATA_ID + " INTEGER PRIMARY KEY REFERENCES data(_id)," +StatusUpdates.STATUS + " TEXT," + //狀態StatusUpdates.STATUS_TIMESTAMP + " INTEGER," + //時間戳StatusUpdates.STATUS_RES_PACKAGE + " TEXT, " + //提供資源的包名StatusUpdates.STATUS_LABEL + " INTEGER, " + //狀態資源idStatusUpdates.STATUS_ICON + " INTEGER" + //狀態圖標id");");這個轉門指通訊工具(例如Google Talk)的狀態,例如在線,隱身等。

DIRECTORIES?

通訊錄表 db.execSQL("CREATE TABLE " + Tables.DIRECTORIES + "(" +Directory._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +Directory.PACKAGE_NAME + " TEXT NOT NULL," +Directory.DIRECTORY_AUTHORITY + " TEXT NOT NULL," + Directory.TYPE_RESOURCE_ID + " INTEGER," +DirectoryColumns.TYPE_RESOURCE_NAME + " TEXT," +Directory.ACCOUNT_TYPE + " TEXT," +Directory.ACCOUNT_NAME + " TEXT," +Directory.DISPLAY_NAME + " TEXT, " +Directory.EXPORT_SUPPORT + " INTEGER NOT NULL" + //后面詳細解釋" DEFAULT " + Directory.EXPORT_SUPPORT_NONE + "," +Directory.SHORTCUT_SUPPORT + " INTEGER NOT NULL" +" DEFAULT " + Directory.SHORTCUT_SUPPORT_NONE + "," +Directory.PHOTO_SUPPORT + " INTEGER NOT NULL" +" DEFAULT " + Directory.PHOTO_SUPPORT_NONE +");");Directory表示一個集合,例如ContactsProvider默認會添加兩個Directory,一個就是之前介紹的的DEFAULT,還有一個是LOCAL_INVISIBLE
/*** _ID of the default directory, which represents locally stored contacts.*/public static final long DEFAULT = 0;/*** _ID of the directory that represents locally stored invisible contacts.*/public static final long LOCAL_INVISIBLE = 1;除了這兩個外,還可以在其他app中實現DirectoryProvider,ContactsProvider會掃描所有的apk,發現AndroidManifest中有 <meta-data android:name="android.content.ContactDirectory" android:value="true"/>都會認為該app是一個DirectoryProvider,ContactsProvider收到相應請求會轉發到相應?AUTHORITY的DirectoryProvider去。

EXPORT_SUPPORT
public static final int EXPORT_SUPPORT_NONE = 0; //不支持導出聯系人public static final int EXPORT_SUPPORT_SAME_ACCOUNT_ONLY = 1; //只能導出到指定的賬戶public static final int EXPORT_SUPPORT_ANY_ACCOUNT = 2; //能導出到任何賬戶SHORTCUT_SUPPORT? public static final int SHORTCUT_SUPPORT_NONE = 0; //不支持快捷方式public static final int SHORTCUT_SUPPORT_DATA_ITEMS_ONLY = 1; //只支持單個data itempublic static final int SHORTCUT_SUPPORT_FULL = 2; //支持全部PHOTO_SUPPORT? public static final int PHOTO_SUPPORT_NONE = 0; //不支持頭像public static final int PHOTO_SUPPORT_THUMBNAIL_ONLY = 1; //小頭像public static final int PHOTO_SUPPORT_FULL_SIZE_ONLY = 2; //大頭像public static final int PHOTO_SUPPORT_FULL = 3; //全部支持DirectoryProvider是針對三方app有自己的聯系人數據,想通過Android標準的聯系人查詢供其它app使用,但是又不暴露自己的數據庫實現,那么就按Android的標準實現一個DirectoryProvider。

SEARCH_INDEX

搜索表 db.execSQL("CREATE VIRTUAL TABLE " + Tables.SEARCH_INDEX+ " USING FTS4 ("+ SearchIndexColumns.CONTACT_ID + " INTEGER REFERENCES contacts(_id) NOT NULL,"+ SearchIndexColumns.CONTENT + " TEXT, " //公司、備注等其它信息+ SearchIndexColumns.NAME + " TEXT, " //名字+ SearchIndexColumns.TOKENS + " TEXT" //號碼+ ")");FTS是Full-Text Search,見全文索引,這個大幅度提高了長文的搜索效率。 這里建立虛表是FTS的要求,更詳細的見sqlite官方網站點擊打開鏈接。注意使用FTS還會有另外5個表自動建立: For each FTS virtual table in a database, three to five real (non-virtual) tables are created to store the underlying data. These real tables are called "shadow tables". The real tables are named "%_content", "%_segdir", "%_segments", "%_stat", and "%_docsize", where "%" is replaced by the name of the FTS virtual table.

DIALER_SEARCH

撥號盤搜索表,見MTK的T9搜索流程分析

CONFERENCE_CALLS

會議通話表,mtk添加的表 db.execSQL("CREATE TABLE " + Tables.CONFERENCE_CALLS + " (" +ConferenceCalls._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +ConferenceCalls.GROUP_ID + " INTEGER REFERENCES groups(_id)," + //對應group idConferenceCalls.CONFERENCE_DATE + " INTEGER " + //日期");");

DATA_USAGE_STAT?

data使用情況統計表 db.execSQL("CREATE TABLE " + Tables.DATA_USAGE_STAT + "(" +DataUsageStatColumns._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +DataUsageStatColumns.DATA_ID + " INTEGER NOT NULL, " + //對應data表的idDataUsageStatColumns.USAGE_TYPE_INT + " INTEGER NOT NULL DEFAULT 0, " + //類型,解釋見下DataUsageStatColumns.TIMES_USED + " INTEGER NOT NULL DEFAULT 0, " + // 使用次數DataUsageStatColumns.LAST_TIME_USED + " INTERGER NOT NULL DEFAULT 0, " + //最后一次使用的時間"FOREIGN KEY(" + DataUsageStatColumns.DATA_ID + ") REFERENCES "+ Tables.DATA + "(" + Data._ID + ")" +");");USAGE_TYPE_INT
public static final String USAGE_TYPE_CALL = "call"; //通話public static final String USAGE_TYPE_LONG_TEXT = "long_text"; //長的文本通信,例如電子郵件public static final String USAGE_TYPE_SHORT_TEXT = "short_text"; //短的文本通信,例如短信

PRE_AUTHORIZED_URIS?

權限表 db.execSQL("CREATE TABLE " + Tables.PRE_AUTHORIZED_URIS + " ("+PreAuthorizedUris._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +PreAuthorizedUris.URI + " STRING NOT NULL, " +PreAuthorizedUris.EXPIRATION + " INTEGER NOT NULL DEFAULT 0);");這個表用于app獲取權限,與Context.grantUriPermission不同的是它不用在代碼中指明要獲取什么權限,授權后5分鐘內可以查詢數據,5分鐘后權限過期。這個表的詳細用法見ContactsContract中的Authorization類。

PRESENCE

db.execSQL("ATTACH DATABASE ':memory:' AS " + DATABASE_PRESENCE + ";");db.execSQL("CREATE TABLE IF NOT EXISTS " + DATABASE_PRESENCE + "." + Tables.PRESENCE + " ("+StatusUpdates.DATA_ID + " INTEGER PRIMARY KEY REFERENCES data(_id)," + //對應data表中的idStatusUpdates.PROTOCOL + " INTEGER NOT NULL," + //協議常量StatusUpdates.CUSTOM_PROTOCOL + " TEXT," + //訂制協議名稱StatusUpdates.IM_HANDLE + " TEXT," + //和協議相關StatusUpdates.IM_ACCOUNT + " TEXT," + //IM賬號PresenceColumns.CONTACT_ID + " INTEGER REFERENCES contacts(_id)," + //對應contacts idPresenceColumns.RAW_CONTACT_ID + " INTEGER REFERENCES raw_contacts(_id)," + //對應raw_contacts idStatusUpdates.PRESENCE + " INTEGER," + //im的在線狀態,解釋見下StatusUpdates.CHAT_CAPABILITY + " INTEGER NOT NULL DEFAULT 0," + //通話能力,解釋見下"UNIQUE(" + StatusUpdates.PROTOCOL + ", " + StatusUpdates.CUSTOM_PROTOCOL+ ", " + StatusUpdates.IM_HANDLE + ", " + StatusUpdates.IM_ACCOUNT + ")" + ");");這個表和AGGREGATED_PRESENCE都是在內存數據庫中,在設備中并沒有對應文件,進程關閉后表就消失,進程開啟后表創建。 IM即使通訊,例如Google Talk。這個表主要是記錄IM的在線狀態 PRESENCE
int OFFLINE = 0; //不在線int INVISIBLE = 1; //隱身int AWAY = 2; //離開int IDLE = 3; //空閑int DO_NOT_DISTURB = 4; //勿擾int AVAILABLE = 5; //在線 CHAT_CAPABILITY public static final int CAPABILITY_HAS_VOICE = 1; //語音public static final int CAPABILITY_HAS_VIDEO = 2; //視頻public static final int CAPABILITY_HAS_CAMERA = 4; //有前置攝像頭

AGGREGATED_PRESENCE

db.execSQL("CREATE TABLE IF NOT EXISTS "+ DATABASE_PRESENCE + "." + Tables.AGGREGATED_PRESENCE + " ("+AggregatedPresenceColumns.CONTACT_ID+ " INTEGER PRIMARY KEY REFERENCES contacts(_id)," +StatusUpdates.PRESENCE + " INTEGER," +StatusUpdates.CHAT_CAPABILITY + " INTEGER NOT NULL DEFAULT 0" +");");字段同PRESENCE表。這個表的修改都在AbstractContactAggregator中,為了聚合聯系人。

總結

以上是生活随笔為你收集整理的联系人存储ContactsProvider表分析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

五月婷婷一区二区三区 | 午夜精品一区二区三区可下载 | 操操碰| 国产黄免费看 | 国产夫妻自拍av | 人人爽人人av | 久久成人黄色 | 成人在线免费观看网站 | 免费久久视频 | 欧美做受高潮电影o | 9999国产精品 | 国产一区二区三区网站 | 国产免费观看av | 午夜国产成人 | 日韩欧美国产成人 | 色婷婷综合成人av | 2019中文| av网站在线免费观看 | 久久精品亚洲 | 成人一区在线观看 | 狠狠夜夜| 国产视频中文字幕在线观看 | 久久中国精品 | 综合色中色 | 蜜桃av综合网 | 97超级碰 | 中文字幕在线观看的网站 | 最近免费中文字幕 | 香蕉网站在线观看 | 三级视频片 | 天天射天天拍 | 超碰97在线人人 | 99热.com| 久久婷婷激情 | 免费观看高清 | www.国产在线观看 | 亚洲激情av | 中文字幕久久精品亚洲乱码 | 国产青春久久久国产毛片 | 一区二区三区免费网站 | 四虎影视成人 | 韩日精品在线 | 国产一二区免费视频 | 美女视频免费精品 | 99精品视频观看 | 色网站在线看 | 国产精品久久久影视 | 色婷婷88av视频一二三区 | 免费av网址在线观看 | 九九热在线视频免费观看 | 天天操 夜夜操 | 久久综合成人网 | 国产五月 | 欧美调教网站 | 九九热久久免费视频 | 波多野结衣理论片 | 色吊丝在线永久观看最新版本 | 在线观看岛国 | a视频在线观看 | 一本一本久久a久久精品综合 | 久久久久国产视频 | 九色免费视频 | 一区视频在线 | 五月婷婷婷婷婷 | 日韩视频一 | 伊人电影在线观看 | 久久露脸国产精品 | 久久99在线 | 中文字幕av有码 | 国产成人免费在线观看 | 黄色一级免费电影 | 亚洲精品中文字幕在线 | 高清国产午夜精品久久久久久 | 欧美一级特黄高清视频 | 精品欧美一区二区在线观看 | 黄色在线看网站 | 激情五月网站 | 久久精品电影院 | 最近2019年日本中文免费字幕 | 国产美女在线免费观看 | 欧美日韩国产亚洲乱码字幕 | 99视频免费看| 91爱爱网址 | 激情久久小说 | 国产一级黄色av | 欧美另类交人妖 | 最新日韩电影 | 国产91精品欧美 | 久久久久电影 | 亚洲一区日韩在线 | 日本三级吹潮在线 | 久久综合加勒比 | 97在线观看免费高清 | 日韩激情av在线 | 最新日韩在线观看视频 | 久久图| 免费观看www7722午夜电影 | 四虎永久免费在线观看 | 在线免费观看涩涩 | 亚洲一区精品人人爽人人躁 | 人人搞人人干 | 91网在线观看 | 国产生活一级片 | 黄色免费国产 | 99久久精品国产网站 | 日本中文字幕免费观看 | 亚洲 欧美 日韩 综合 | 97超碰免费在线 | av天天色 | 精品久久久久久久久久久久久久久久久久 | 欧美性性网 | 黄色电影在线免费观看 | 国产亚洲成人网 | 国产黄色视| 特级西西人体444是什么意思 | av日韩国产 | 97在线观视频免费观看 | 九九九热精品免费视频观看网站 | 精品久久久久久久久久久久 | 国产69精品久久久久9999apgf | 国产麻豆视频网站 | 四虎影视4hu4虎成人 | 日韩丝袜在线观看 | 最新精品视频在线 | 久草资源免费 | 在线а√天堂中文官网 | 91av小视频 | 五月婷婷开心 | 美女网站视频久久 | 999久久久免费视频 午夜国产在线观看 | 欧美日韩精品影院 | 久青草国产在线 | 五月天婷婷丁香花 | 日韩在线观看三区 | 二区三区av | 狠狠干天天 | 免费合欢视频成人app | 日韩a欧美 | 麻豆成人小视频 | 黄色官网在线观看 | 亚洲国产成人在线播放 | 香蕉视频导航 | 碰超人人 | 亚洲色图27p| 久久国产精品久久久 | 欧美精品久久久久a | 日本精品久久 | 黄色av成人在线观看 | 国产在线精品一区二区不卡了 | 亚洲最新av | 亚洲欧美日韩精品久久奇米一区 | 在线成人性视频 | 91亚洲在线观看 | 色射色| 91精品国产自产91精品 | 91精品国产成人 | 日本久久久久久久久 | 黄色一级影院 | av线上看| 国产糖心vlog在线观看 | 2023亚洲精品国偷拍自产在线 | av在线一二三区 | 99视频在线观看一区三区 | 四虎成人精品在永久免费 | 国产精品美女久久久久久网站 | 99精品久久只有精品 | 天堂av在线免费 | 91九色国产 | 99产精品成人啪免费网站 | 色噜噜在线观看 | 国产精品久久久久久久久久免费 | 国产又粗又猛又黄又爽 | 国产91精品高清一区二区三区 | 国产一及片 | 97在线公开视频 | 天天爽天天搞 | 日韩美av在线 | 少妇bbbb| 天天操天天添天天吹 | 手机看片99 | 中文在线| 久一网站 | 91成人免费 | 国产手机在线播放 | 中文日韩在线 | 精品免费视频 | 在线观看日韩精品 | 五月的婷婷 | 涩涩网站在线 | 天天久久夜夜 | 五月天中文字幕mv在线 | 欧美九九九 | 久草视频免费播放 | 国产一区二区三精品久久久无广告 | 天天色天天爱天天射综合 | 精品亚洲免费视频 | 日韩精品中文字幕在线不卡尤物 | 国产黄色片免费 | 激情开心站 | 在线观看亚洲成人 | 色婷婷狠狠五月综合天色拍 | 国产精品久久一区二区三区不卡 | 欧美a视频在线观看 | 91成人蝌蚪| 国产黄色片一级三级 | 九九亚洲视频 | www五月婷婷 | 天堂av在线中文在线 | 亚洲精品高清视频 | 亚洲成人av片在线观看 | 日本中文字幕一二区观 | www.伊人网| 欧美性视频网站 | 久久韩国免费视频 | 精品久久久久久国产偷窥 | 免费av在线网| 9ⅰ精品久久久久久久久中文字幕 | 日韩精品中文字幕在线不卡尤物 | 激情大尺度视频 | 精品中文字幕在线 | 精品视频成人 | 99精品视频精品精品视频 | 在线日本看片免费人成视久网 | 亚洲精品99久久久久久 | 在线观看色网 | 欧美精品在线一区二区 | 免费a v在线 | 色视频网页 | 不卡的av电影 | 午夜视频色 | 久久美女免费视频 | 夜添久久精品亚洲国产精品 | 91精品国产自产老师啪 | 日韩电影中文字幕在线观看 | 91精品色 | 亚洲涩涩涩涩涩涩 | 国产 字幕 制服 中文 在线 | 在线观看国产www | 91九色视频网站 | 色干干| 精品久久精品久久 | 国产在线一区二区 | 黄色一级动作片 | 久久毛片高清国产 | 国产精品日韩欧美 | 91网页版免费观看 | 国产婷婷久久 | 91最新中文字幕 | 国产精品男女啪啪 | 99精品国产免费久久久久久下载 | 懂色av一区二区在线播放 | 国产精品h在线观看 | 激情综合网色播五月 | 久久免费视频一区 | 人人爽人人av | 97人人澡人人添人人爽超碰 | 久久精品国产成人精品 | 日韩av成人在线 | 亚洲精品视频网站在线观看 | 久久综合亚洲鲁鲁五月久久 | 天天操天天射天天 | 在线观看中文av | 国产成人免费在线观看 | 欧美天堂影院 | 色婷婷福利视频 | 成人动漫视频在线 | 日韩精品中字 | 国产区久久 | 国内精品久久久久久久久久久久 | 8090yy亚洲精品久久 | 精品1区2区3区 | 91热这里只有精品 | 91最新视频在线观看 | 日韩免费高清在线观看 | 欧美性生活久久 | 久久99免费| 免费av网站在线 | 91视频免费 | 99久久久国产精品免费99 | 国产一级性生活 | 五月天网站在线 | 亚洲少妇自拍 | 91天堂在线观看 | 国产女人40精品一区毛片视频 | 婷婷综合久久 | 免费一级特黄录像 | 久久tv| 亚洲成人av电影 | 国产在线999 | 国内99视频 | 粉嫩av一区二区三区入口 | av解说在线 | 91av网址 | 国产99精品在线观看 | 中文字幕在线免费看 | 国产亚洲永久域名 | 在线观看亚洲a | 午夜久久精品 | 视色网站 | 国产看片 色 | 精品国产伦一区二区三区观看方式 | 四虎成人精品永久免费av九九 | 亚洲国产中文字幕在线 | 91精品视频免费在线观看 | 国产精品二区在线 | 国产 日韩 欧美 中文 在线播放 | 国产高清视频网 | 久操视频在线观看 | 国产中文自拍 | 婷婷丁香九月 | 超碰97免费观看 | 国产在线2020 | 国产精品九色 | 极品嫩模被强到高潮呻吟91 | 国产高清免费视频 | 91精品伦理 | 久草视频观看 | 日韩r级电影在线观看 | 91麻豆精品久久久久久 | 国产精品都在这里 | www.狠狠操 | 在线观看麻豆av | 国语对白少妇爽91 | 91九色丨porny丨丰满6 | 国产精品video爽爽爽爽 | 日韩av影视在线 | 成年人在线观看视频免费 | 国产91丝袜在线播放动漫 | 91九色在线观看视频 | 亚洲在线黄色 | 激情综合六月 | 国产精品自拍av | 一级全黄毛片 | 国产日韩精品欧美 | av3级在线 | 国产精品 999| bbw av| 涩涩成人在线 | 国产亚洲精品美女久久 | 五月婷婷.com | 最近中文国产在线视频 | 天天躁天天操 | 国产性天天综合网 | 亚洲在线视频观看 | 97超碰在线视 | 免费看的黄网站软件 | 午夜影院日本 | 五月婷婷综合在线观看 | 色在线观看网站 | 不卡视频在线看 | 国产精品久久久久久久久久了 | 日韩精品久久一区二区 | 丁香婷婷激情国产高清秒播 | 久久免费美女视频 | 欧美在线视频一区二区三区 | 国产又黄又硬又爽 | 国产精品久久久久久久久久久免费 | 日韩在线三区 | 天堂av网址 | 免费看的黄色网 | 黄色三级免费片 | 在线观看午夜av | 精品国内自产拍在线观看视频 | 成人一级片免费看 | 狠狠躁天天躁综合网 | 日韩在线视频一区二区三区 | 国产精品久久久久国产精品日日 | 久久伦理电影网 | 亚洲综合小说电影qvod | 亚洲国产精品激情在线观看 | 一区二区久久久久 | 国产亚洲一区二区在线观看 | 欧美性春潮 | 久久综合欧美精品亚洲一区 | 韩国一区在线 | 三级av网| 婷五月激情 | 国产麻豆精品久久一二三 | 亚洲美女视频在线观看 | 久久久亚洲网站 | 免费大片av | 国产精品h在线观看 | 日韩国产欧美在线视频 | 天天爽人人爽 | 成人综合婷婷国产精品久久免费 | 五月婷香蕉久色在线看 | 中文字幕一区在线 | 热久久99这里有精品 | 91成品视频 | 天天色影院 | 国产在线观看av | 国产精品网红福利 | 97超碰国产精品女人人人爽 | 久久久久国产一区二区三区四区 | 国产一级二级在线播放 | 日韩高清一区在线 | 久久伊人热 | 麻豆久久久| 日日夜夜人人天天 | 成年人视频在线免费观看 | 特黄免费av | 九九久久视频 | 日日日日 | 日日夜夜精品视频天天综合网 | 97中文字幕 | 超碰在线97观看 | 中文乱码视频在线观看 | 色视频网站免费观看 | 中文字幕在线视频免费播放 | 国产又粗又硬又爽视频 | 玖玖视频在线 | 免费视频成人 | 免费在线一区二区三区 | 色亚洲网 | 亚洲精品字幕在线 | 一级片在线 | 夜夜骑日日操 | 久久久久久美女 | 五月婷婷丁香六月 | 黄污网 | 午夜av一区 | 欧美亚洲精品在线观看 | 国产精品videossex国产高清 | 国产精品 日韩 | 麻豆视频免费入口 | 久久久久久久久久网 | 国产一区二区在线观看视频 | 欧美va在线观看 | 久久国产精品免费一区二区三区 | 天天操天天色综合 | 久久免费看a级毛毛片 | 国内精品久久久久久久久久清纯 | 国内精品久久久久久中文字幕 | 99精彩视频在线观看免费 | 免费看片网址 | 欧美精品你懂的 | 中文字幕在线观看视频网站 | 五月综合婷 | 色综合色综合久久综合频道88 | 亚洲国产中文在线 | 色九九视频 | 在线免费中文字幕 | 黄色一级大片在线观看 | 国内精品久久久久影院一蜜桃 | 成人黄色在线播放 | 国产视频中文字幕 | 手机版av在线 | 欧美色图东方 | 色综合网 | 91精品免费在线观看 | 成人av在线电影 | 久久精品这里都是精品 | 亚洲91中文字幕无线码三区 | 九九免费在线观看视频 | 久久69av| 黄色三级免费看 | 91精品视频在线观看免费 | 婷婷综合网 | 日韩精品视频在线观看免费 | 色噜噜日韩精品欧美一区二区 | 国产成人精品网站 | 久久影院亚洲 | 国产午夜av | 在线看日韩av | 97精品国产一二三产区 | 日韩天堂网 | 国产在线成人 | 黄在线| 久久免费99精品久久久久久 | 国产69久久久欧美一级 | 97超碰成人在线 | 青春草视频| 婷婷综合av | 久久久国产精品亚洲一区 | 黄色中文字幕在线 | 久久久影片 | 成人啊 v| 国产涩图| 五月婷婷综合久久 | 涩涩网站免费 | 久久9999久久 | 9797在线看片亚洲精品 | 亚洲一区日韩 | 免费a v在线 | 五月婷婷在线观看 | 成人小视频在线 | 91大神电影| 青青草国产精品 | 永久中文字幕 | 日韩激情第一页 | 99久久一区 | av不卡在线看 | 欧美不卡视频在线 | 蜜臀av夜夜澡人人爽人人桃色 | 91久久国产综合精品女同国语 | 欧美日韩国产伦理 | 久草在线一免费新视频 | 在线免费视 | 亚州精品天堂中文字幕 | 中文av网| 国产涩涩在线观看 | 区一区二在线 | 精品国产乱码久久久久 | 亚洲成人资源网 | 极品嫩模被强到高潮呻吟91 | 玖玖在线精品 | 午夜精品福利在线 | 国产精品毛片久久久久久久久久99999999 | 一区在线观看 | 91字幕| 欧美日韩色婷婷 | 久久99久久99精品中文字幕 | 五月情婷婷 | 91麻豆精品国产91 | 亚洲专区在线播放 | 在线国产高清 | 国产成视频在线观看 | 久久字幕 | 成人国产亚洲 | 一区二区三区电影 | 欧美大香线蕉线伊人久久 | 绯色av一区 | 国产亚洲在线视频 | 国产精品成人一区二区 | 91丨九色丨高潮丰满 | 日韩av影片在线观看 | 成人黄色在线视频 | 久久精彩| 99久久婷婷国产综合精品 | 激情五月视频 | 国产亚洲情侣一区二区无 | av片一区 | 国产精品入口麻豆www | 国产在线观看免费 | 国产精品成人a免费观看 | 五月婷影院 | 色婷婷电影 | 久久草网站 | 蜜桃传媒一区二区 | 欧美大片在线观看一区 | 欧美一区三区四区 | 日韩在线观看一区 | 天天综合成人网 | 一区二区视频欧美 | 日韩中文字 | 国产精品24小时在线观看 | 国内成人精品2018免费看 | 国产精品va| 国产精品久久久久9999吃药 | 96av在线视频 | 国产精品美女久久久 | 国产美女精彩久久 | 免费在线播放av电影 | 五月天视频网站 | 2018亚洲男人天堂 | 午夜国产福利在线 | 一区二区三区免费在线观看视频 | 亚洲高清免费在线 | 欧美成人h版电影 | 天天射综合 | 日本激情视频中文字幕 | 成人在线视频在线观看 | 久久视频网 | 91污视频在线观看 | av看片网| 成人av av在线 | 中文字幕a∨在线乱码免费看 | 九色在线| www久久| 精品在线观看一区二区三区 | 国产一区二区三区免费视频 | 久久久资源网 | wwwwwww黄| 国产96精品| 日操干| 色综合久久久久久久久五月 | 日韩精品一区二区三区高清免费 | 久久综合国产伦精品免费 | 在线免费观看视频你懂的 | 日日爱av | 96视频免费在线观看 | 亚洲aⅴ一区二区三区 | 免费看的av片 | 国产91电影在线观看 | 综合网婷婷 | 久久99热久久99精品 | 欧美日比视频 | 亚州黄色一级 | 欧美成年黄网站色视频 | 精品乱码一区二区三四区 | 丝袜制服综合网 | 久久久久久久久久久免费 | 欧美疯狂性受xxxxx另类 | 九色porny真实丨国产18 | 人人射人人爱 | 日韩精品免费一区二区在线观看 | 亚洲激情综合网 | 黄色av一级 | 青青五月天 | 瑞典xxxx性hd极品 | 久久好看免费视频 | 国产精品久久久久一区 | 色婷婷在线视频 | 亚洲国产中文字幕在线观看 | 成人在线免费看 | freejavvideo日本免费 | 国产精品a久久久久 | 激情五月婷婷激情 | 在线成人一区 | 日产中文字幕 | 午夜的福利 | 国产精品久久久久一区二区三区 | 日本性高潮视频 | 日日操网 | 波多野结衣视频一区 | 日韩成人免费在线电影 | 黄色三级免费网址 | 久久99热精品| 91高清一区 | 久久久精品网 | 激情小说网站亚洲综合网 | 亚洲精品国产精品国 | 最新日本中文字幕 | 亚洲免费公开视频 | 欧美三级在线播放 | 国产精品毛片一区二区 | 极品美女被弄高潮视频网站 | 成 人 黄 色 片 在线播放 | 欧美天天综合 | 中文字幕日韩有码 | 欧美人操人 | 伊人色综合久久天天 | av一区在线| 免费色网 | 日韩最新中文字幕 | 国产精品久久久av久久久 | 日韩在线观看免费 | 精品视频| 亚洲国内精品视频 | 国产一区高清在线观看 | 欧美a级在线免费观看 | 亚洲国产成人高清精品 | 色综合天天色 | 色天堂在线视频 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 婷婷丁香在线视频 | 黄色小说18| 五月婷婷综合在线观看 | 99精品视频在线免费观看 | 国产精品激情在线观看 | 超碰夜夜 | 成年人免费在线观看网站 | 国产色在线,com | 国产一级二级三级视频 | 69精品| 久久黄色a级片 | 国产区av在线 | 国产成人精品亚洲精品 | 久久色视频 | 日本精品视频一区二区 | 91亚洲视频在线观看 | 国产精品影音先锋 | av资源免费看 | 国产精品欧美一区二区 | 91网址在线观看 | 欧美精品午夜 | 天天射天天艹 | 午夜神马福利 | 免费看毛片网站 | 激情丁香 | 亚洲1级片 | 国产一区高清在线观看 | 97电影网站 | 五月婷婷视频在线观看 | 天天干,夜夜爽 | 韩日三级在线 | 久久国产欧美日韩精品 | 亚洲综合色播 | 国产免费观看视频 | 久久综合色婷婷 | 精品网站999www | 啪啪凸凸 | 三级黄色理论片 | 欧美一性一交一乱 | 免费看污片 | 一区二区视频免费在线观看 | 夜夜夜夜夜夜操 | 91精品国产麻豆 | 久草干| 欧美激情综合网 | www天天干 | 成人三级网址 | 色精品视频 | 国产精品毛片一区二区 | 亚洲精品久久久久久久不卡四虎 | 97超碰超碰久久福利超碰 | 日韩欧美网址 | 91丨九色丨蝌蚪丨老版 | 97在线看 | 国产精品二区在线 | 中文字幕一区二区三区四区在线视频 | 97在线观 | 国产精品一区免费看8c0m | 欧美在线观看视频免费 | 69国产盗摄一区二区三区五区 | 免费a v视频 | 99精品免费网 | 蜜臀av在线一区二区三区 | 国产黄色片网站 | 国产美女精品久久久 | 久久久久久久久福利 | av成人免费观看 | 91桃花视频 | 国产亚洲久久 | 嫩模bbw搡bbbb搡bbbb | 亚洲精选国产 | 黄色日本片| 久草国产视频 | 青青射| 99精品国产高清在线观看 | 精品国产伦一区二区三区 | 国产无区一区二区三麻豆 | 中文国产在线观看 | 国产精品私人影院 | 久久综合网色—综合色88 | 国产精品原创av片国产免费 | 亚洲最大成人网4388xx | 久久国产精品系列 | 美女视频黄的免费的 | 亚洲日日射 | 精品在线亚洲视频 | 美国av片在线观看 | 国产精品女主播一区二区三区 | 狠狠躁日日躁 | 欧美日韩国产精品爽爽 | www视频在线观看 | 久久精品国产99 | 91久久久久久久 | 91麻豆精品国产91久久久久久久久 | 久久久久成人精品免费播放动漫 | 2020天天干天天操 | 超碰激情在线 | 国产精品久久伊人 | 国产精品国产三级国产aⅴ9色 | 国产精在线| 深爱婷婷久久综合 | 中文字幕美女免费在线 | 国产明星视频三级a三级点| 国产免费久久久久 | 国产午夜免费视频 | 精品视频免费 | 亚洲国内精品 | 福利一区二区三区四区 | 西西4444www大胆艺术 | av日韩在线网站 | 国产精品一区二区三区在线免费观看 | 国产亚洲在 | 亚洲另类在线视频 | 久精品一区 | 在线成人小视频 | 98久久 | 日日摸日日爽 | 国产亚洲精品久久网站 | 久久精品国产第一区二区三区 | 欧美va电影| 久久久久久久亚洲精品 | 毛片网站在线观看 | 欧美久草视频 | 狠狠的日| 毛片网站在线 | 夜添久久精品亚洲国产精品 | 在线观看亚洲成人 | 天天插天天狠 | 色综合久久五月天 | 亚洲三级毛片 | 亚洲欧美国内爽妇网 | 欧美一级欧美一级 | 亚洲欧洲国产视频 | 亚洲精品免费在线视频 | 国产日产欧美在线观看 | 午夜精品一区二区三区四区 | 亚洲精品美女久久久久 | 日韩啪视频 | 午夜10000| 九九久久精品 | 国产精品久久久久久久久费观看 | 久久综合狠狠综合 | 国产精品va视频 | 美女视频黄的免费的 | 免费亚洲视频 | 天堂av在线网站 | 亚洲一区免费在线 | 中文字幕丰满人伦在线 | 婷婷狠狠操 | 成年人在线播放视频 | 黄视频网站大全 | 精品国产伦一区二区三区观看方式 | 毛片一级免费一级 | 亚洲国产视频a | av福利免费 | 国产福利av | 超碰在线人人 | 久久好看免费视频 | 色婷婷中文| 欧美性爽爽 | www.久久久.cum| 亚洲欧美视频 | 婷婷五情天综123 | 最近中文字幕在线中文高清版 | 天天操天天干天天操天天干 | 国产精品刺激对白麻豆99 | 国产精品久久久久久模特 | 欧美污污视频 | 丁香婷婷激情国产高清秒播 | av超碰在线| 国产精品va| 精品视频免费在线 | 欧美激情在线网站 | 国产精品一区二区久久久 | 国内精品久久久久久久久久久 | 最新影院| 九九国产视频 | 999视频网站 | 国产精品欧美一区二区三区不卡 | 欧美精品二 | 中文国产字幕 | 中文字幕电影一区 | 97国产精品| 久久字幕网 | 天天操夜夜拍 | 成年人在线观看免费视频 | 深爱激情五月婷婷 | av黄在线播放 | 999热视频 | 激情伊人 | 人人狠狠综合久久亚洲 | 中文字幕免费观看视频 | 久久夜色网 | 日韩在线观看网站 | 亚洲日本va中文字幕 | 日本中文字幕视频 | 韩国av不卡 | 色com| 欧美极品久久 | 国产精品一码二码三码在线 | 9热精品 | 91精品一区二区三区久久久久久 | 午夜精品一区二区三区视频免费看 | 免费观看成人 | 乱男乱女www7788 | 国产一区二三区好的 | 国产精品欧美一区二区三区不卡 | 欧美乱熟臀69xxxxxx | 美腿丝袜一区二区三区 | 狠狠色丁香婷婷综合久久片 | 午夜视频色 | 久草在线视频首页 | 五月天伊人网 | 亚洲一区美女视频在线观看免费 | 又色又爽又激情的59视频 | 日韩超碰在线 | 精品嫩模福利一区二区蜜臀 | 日本黄色一级电影 | 网址你懂的在线观看 | 精品福利在线视频 | 午夜视频在线瓜伦 | 久久精品99国产精品酒店日本 | 亚洲日本va在线观看 | 午夜成人免费影院 | 中文字幕国产精品 | 国产尤物在线 | 欧美另类高清 videos | 久久免费视频网站 | 色综合久久88色综合天天人守婷 | 色婷久久| 国产精品美女久久久久久久 | 欧美日韩久久一区 | 精品国产123 | 亚洲国产午夜视频 | av中文在线观看 | 亚洲精品国产精品久久99热 | 97免费视频在线 | 日韩欧美网站 | 色99色| 天天综合入口 | 国产精品扒开做爽爽的视频 | 天堂在线视频中文网 | 国产精品麻豆三级一区视频 | 欧美在线日韩在线 | 成人手机在线视频 | 日韩美在线观看 | 欧美伦理电影一区二区 | 蜜臀av一区二区 | 青青河边草免费视频 | 成人久久综合 | 精壮的侍卫呻吟h | 国产三级精品三级在线观看 | www狠狠| 国产精品欧美一区二区 | 91桃色视频 | 欧美色图视频一区 | a资源在线 | 女人18精品一区二区三区 | 中文字幕在线视频免费播放 | 亚洲色影爱久久精品 | www免费| 国产无吗一区二区三区在线欢 | 国产精品视频不卡 | 国产一二三精品 | 亚洲午夜精品电影 | 亚洲极色 | 国产精品久久久久久久久免费 | 国产免费一区二区三区网站免费 | 欧洲精品视频一区二区 | 欧美大片aaa | 国产精品资源 | 欧美一级大片在线观看 | 久草在线资源观看 | av一级片在线观看 | 九九热在线免费观看 | 亚洲国产成人在线 | 在线观看蜜桃视频 | 九色porny真实丨国产18 | 视频在线观看入口黄最新永久免费国产 | 久久久精品国产一区二区电影四季 | 久久久久麻豆v国产 | 国产福利资源 | 成人黄色av网站 | 777久久久| 丁香在线观看完整电影视频 | 国产剧情一区二区在线观看 | 久久综合加勒比 | 激情六月婷婷久久 | 97成人资源站 | 欧美久久久一区二区三区 | 高清av中文在线字幕观看1 | av免费高清观看 | 国产一区二区精品久久91 | 精品国产伦一区二区三区观看方式 | 中文字幕高清有码 | 97av视频 | 精品久久久成人 | 国产美女精彩久久 | 亚洲黄网站 | 久亚洲| 国产精品一区在线观看 | 成人av午夜| 国产精品免费高清 | 免费观看一级特黄欧美大片 | 久久 一区 | 久久久久福利视频 | 天天干天天干天天 | 久久久精品福利视频 | 三级黄色片在线观看 | 成年人黄色大片在线 | 在线观看视频中文字幕 | 91精品爽啪蜜夜国产在线播放 | 午夜精品久久久久久久爽 | 欧美日一级片 | 国产裸体永久免费视频网站 | 99在线观看视频 | 国产精品成人免费一区久久羞羞 | 婷婷丁香六月天 | 国产高清精品在线观看 | 欧美最猛性xxxxx亚洲精品 | 日本久久片 | www.超碰| 最近最新mv字幕免费观看 | 国产色拍 | www.香蕉视频 | 亚洲精品小视频在线观看 | 综合网婷婷 | 国产爽妇网 | 亚洲一区二区三区在线看 | 免费看黄色91 | 亚洲免费视频在线观看 | 欧美在线18 | 国产精品久久久久久久久费观看 | 天天干天天想 | 九九激情视频 | 国产一区自拍视频 | a黄色片在线观看 | 欧美精品一区二区蜜臀亚洲 | 天天综合色天天综合 | 中文字幕在线观看完整 | 国产精品视频最多的网站 | 99免费国产| 日日夜夜91 | 国产精品av免费观看 | 久久精品久久精品久久精品 | 精品欧美一区二区精品久久 | 精品网站999www| 婷婷丁香激情网 | 亚洲日本三级 | 免费国产在线观看 | 在线看的av网站 | 91中文在线 | 久久成人在线视频 |