精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

微軟WP7本地數據庫之Sterling編程技巧

數據庫 其他數據庫 數據庫運維
Sterling是一款開源的嵌入式數據庫軟件。在本篇中,我們將分析如何把Sterling數據庫集成到Windows Phone 7程序中及相應的編程技巧和注意事項。

Sterling是一款開源的嵌入式數據庫軟件。在本篇中,我們將分析如何把Sterling數據庫集成到Windows Phone 7程序中及相應的編程技巧和注意事項。

一、創建MainViewModel

為了實現更加模塊化的設計,我們將創建一個視圖模型,用以封裝上篇中定義的兩個數據庫表格。為簡單起見,我們主要提供了數據加載方面的支持。使用MainViewModel的另一個原因是下載的示例程序中正是使用了這種系統架構方式。然而,請注意這個例子中并沒有利用流行的MVVM設計模式。

列表1:定義主視圖模型實現與Sterling數據庫層的關聯

  1. public class MainViewModel : INotifyPropertyChanged  
  2. {  
  3.    public MainViewModel()  
  4.    {  
  5.       this.Groups = new ObservableCollection();  
  6.       this.Contacts = new ObservableCollection();  
  7.    }  
  8.    public ObservableCollection Groups { getprivate set; }  
  9.    public ObservableCollection Contacts { getprivate set; }  
  10.    public bool IsDataLoaded  
  11.    {  
  12.       get;  
  13.       private set;  
  14.    }  
  15.    public void LoadData()  
  16.    {  
  17.       bool hasKeys = false;  
  18.       foreach (var item in App.Database.Query())  
  19.       {   
  20.          hasKeys = true;  
  21.          break;  
  22.       }  
  23.       bool hasKeys2 = false;  
  24.       foreach (var item in App.Database.Query())  
  25.       {  
  26.          hasKeys2 = true;  
  27.          break;  
  28.       }  
  29.       if (!hasKeys && !hasKeys2)  
  30.       {  
  31.          _SetupData();  
  32.       }  
  33.       foreach (var item in App.Database.Query())  
  34.       {  
  35.          Groups.Add(item.LazyValue.Value);  
  36.       }  
  37.       foreach (var item in App.Database.Query())  
  38.       {  
  39.          Contacts.Add(item.LazyValue.Value);  
  40.       }  
  41.       this.IsDataLoaded = true;  
  42.    }  
  43.    private void _SetupData()  
  44.    {  
  45.       var groupData = new List()  
  46.       {  
  47.          new GroupViewModel() { GroupName = "GP1"},  
  48.          //others omitted…  
  49.          new GroupViewModel() { GroupName = "GP10"}  
  50.       };  
  51.       foreach (var item in groupData)  
  52.       {  
  53.          App.Database.Save(item);  
  54.       }  
  55.       var contactData = new List()  
  56.       {  
  57.          new ContactViewModel() { GroupId=1,Name="Name11",Email="Name11@hotmail.com",ThumbNail="/WP7SterlingLearning;Component/ThumbNails/11.jpg"},  
  58.          new ContactViewModel() { GroupId=1,Name="Name12",Email="Name12@hotmail.com",ThumbNail="/WP7SterlingLearning;Component/ThumbNails/12.jpg"},  
  59.          //others omitted…  
  60.          new ContactViewModel() { GroupId=10,Name="Name105",Email="Name105@hotmail.com",ThumbNail="/WP7SterlingLearning;Component/ThumbNails/105.jpg"}  
  61.       };  
  62.       foreach (var item in contactData)  
  63.       {  
  64.          App.Database.Save(item);  
  65.       }  
  66.    }  
  67.    public event PropertyChangedEventHandler PropertyChanged;  
  68.    private void NotifyPropertyChanged(String propertyName)  
  69.    {  
  70.       PropertyChangedEventHandler handler = PropertyChanged;  
  71.       if (null != handler)  
  72.       {  
  73.          handler(thisnew PropertyChangedEventArgs(propertyName));  
  74.       }  
  75.    }  

很容易看出,上面代碼的關鍵在于方法LoadData。在這個方法中,我們首先判斷這兩個表GroupViewModel和ContactViewModel是否已建立。如果已經建立,我們只需要用簡單的Sterling查詢操作填充兩個集合;否則,我們調用另一個方法_SetupData生成新表中的記錄。創建記錄簡單地對應于創建相關類的實例。***,我們設置全局變量IsDataLoaded的值以方便隨后的判斷之用。

到目前為止,所有數據層相關編程已經完成。接下來,我們將介紹如何把Sterling集成到Windows Phone7應用程序中。

#p#

二、把Sterling集成到WP7項目中

現在,我們已經定義了一個Sterling數據庫、兩個表及相應的索引。那么,接下來我們來分析如何把Sterling數據庫集成到我們的示例應用程序WP7SterlingLearning中。請注意,WP7SterlingLearning僅是一個普通的Windows Phone7應用程序,沒有什么特別之處。從總體上看,關鍵的問題主要發生在文件App.xaml.cs中。

1.添加所需的組件

若要使用Sterling數據庫,首先要添加使用Sterling引擎所需的組件。下面給出關鍵代碼部分:

列表2:添加使用Sterling引擎所需的組件的關鍵代碼

  1. //省略其他引用…  
  2. using Wintellect.Sterling;  
  3. using WP7SterlingLearning.Database;  
  4. namespace WP7SterlingLearning  
  5. {  
  6.    public partial class App : Application  
  7.    {  
  8.       private static MainViewModel viewModel = null;  
  9.       private static ISterlingDatabaseInstance _database = null;  
  10.       private static SterlingEngine _engine = null;  
  11.       private static SterlingDefaultLogger _logger = null;  
  12.       //The MainViewModel object  
  13.       public static MainViewModel ViewModel  
  14.       {  
  15.          get 
  16.          {     
  17.             if (viewModel == null)  
  18.                viewModel = new MainViewModel();  
  19.             return viewModel;  
  20.          }  
  21.       }  
  22.       public static ISterlingDatabaseInstance Database  
  23.       {  
  24.          get 
  25.          {  
  26.              return _database;  
  27.          }  
  28.       }  
  29.       //… 

注意,上面的全局靜態屬性Database的定義有助于在應用程序的各處引用這一數據庫。此外,另一個全局靜態屬性ViewModel也起著類似的作用。

其次,我們定義了兩個輔助方法。***個方法_ActivateEngine旨在當程序***啟動時或者當程序從墓碑(tombstone)事件中喚醒時激活數據庫ContactsDatabase。第二個方法_DeactivateEngine用于當應用程序退出或進入到墓碑(tombstone)事件中時停用Sterling引擎。

列表3:方法_ActivateEngine的關鍵代碼部分

  1. private void _ActivateEngine()  
  2. {  
  3.    _engine = new SterlingEngine();  
  4.    _logger = new SterlingDefaultLogger(SterlingLogLevel.Information);  
  5.    _engine.Activate();  
  6.    _database = _engine.SterlingDatabase.RegisterDatabase();  
  7.    //register triggers  
  8.    var maxIdx1 =  
  9.    _database.Query().Any() ?  
  10.    (from id in _database.Query()  
  11.    select id.Key).Max() + 1 : 1;  
  12.    _database.RegisterTrigger(new ContactsDatabase.GroupTrigger(maxIdx1));  
  13.    var maxIdx2 =  
  14.    _database.Query().Any() ?  
  15.    (from id in _database.Query()  
  16.    select id.Key).Max() + 1 : 1;  
  17.    _database.RegisterTrigger(new ContactsDatabase.ContactTrigger(maxIdx2));  
  18. }  
  19.  
  20. private void _DeactivateEngine()  
  21. {  
  22.    _logger.Detach();  
  23.    _engine.Dispose();  
  24.    _database = null;  
  25.    _engine = null;  

這里有幾點值得注意。首先,我們使用內置的Sterling日志記錄器簡單地把執行結果輸出到調試窗口。事實上,Sterling也支持編寫自定義日志記錄器并注冊到Sterling引擎。然而,有關編寫自定義日志記錄器的問題已經超出了本文的范圍。其次,通過調用方法RegisterDatabase我們把數據庫注冊到Sterling引擎中。第三,我們把兩個先前定義的觸發器通過數據庫的RegisterTrigger方法注冊到Sterling引擎。

2.在WP7生命周期事件中控制Sterling引擎

現在,我們可以使用Windows Phone 7應用程序的四個典型的生命周期事件的編程來調用上面的兩個輔助方法。

列表4:在WP7應用程序生命周期事件中控制Sterling引擎

  1. private void Application_Launching(object sender, LaunchingEventArgs e)  
  2. {  
  3.    _ActivateEngine();  
  4. }  
  5. private void Application_Activated(object sender, ActivatedEventArgs e)  
  6. {  
  7.    _ActivateEngine();  
  8.    if (!App.ViewModel.IsDataLoaded)  
  9.    {  
  10.       App.ViewModel.LoadData();  
  11.    }  
  12. }  
  13. private void Application_Deactivated(object sender, DeactivatedEventArgs e)  
  14. {  
  15.    _DeactivateEngine();  
  16. }  
  17. private void Application_Closing(object sender, ClosingEventArgs e)  
  18. {  
  19.    _DeactivateEngine();  

有關Windows Phone 7應用程序的上述四個生命周期事件的解釋,請參考其他的Windows Phone 7入門性文章,在此不再贅述。

截至目前,Sterling數據庫大部分的相關工作已經完成。隨后的任務是把Sterling數據庫結合進WP7視圖頁面的編程中。

#p#

三、編寫視圖頁面

現在,讓我們來看看如何編寫兩個示例網頁。首先,***個頁面MainPage.xaml的構建非常簡單,僅僅使用一個ListBox控件來顯示組數據列表。

列表5: 主視圖頁面XAML關鍵標記代碼

  1. <ListBox x:Name="MainListBox" Margin="0,0,-12,0" ItemsSource="{Binding Groups}"   
  2. SelectionChanged="MainListBox_SelectionChanged"> 
  3.     <ListBox.ItemTemplate> 
  4.         <DataTemplate> 
  5.             <StackPanel Margin="0,0,0,17" Width="432" Orientation="Horizontal"> 
  6.                 <TextBlock Text="{Binding GroupId}" TextWrapping="Wrap"   
  7. Style="{StaticResource PhoneTextExtraLargeStyle}"/> 
  8.                 <TextBlock Text="{Binding GroupName}" TextWrapping="Wrap" Margin="12,-  
  9. 6,12,0" Style="{StaticResource PhoneTextSubtleStyle}"/> 
  10.             </StackPanel> 
  11.         </DataTemplate> 
  12.     </ListBox.ItemTemplate> 
  13. </ListBox> 

現在,稍有Siverlight經驗的讀者應當都會理解上面的標記代碼。這里通過使用基本的數據綁定技術(我們使用ListBox)來渲染GroupViewModel實例的每一個屬性值。

接下來,讓我們看看主視圖頁面后臺代碼編寫的情況。

列表6:主視圖頁面后臺關鍵代碼

  1. namespace WP7SterlingLearning  
  2. {  
  3.    public partial class MainPage : PhoneApplicationPage  
  4.    {  
  5.       public MainPage()  
  6.       {  
  7.          InitializeComponent();  
  8.          DataContext = App.ViewModel;  
  9.          this.Loaded += new RoutedEventHandler(MainPage_Loaded);  
  10.       }  
  11.       private void MainListBox_SelectionChanged(object sender, SelectionChangedEventArgs e)  
  12.       {  
  13.          if (MainListBox.SelectedIndex == -1)  
  14.             return;  
  15.          NavigationService.Navigate(new Uri("/ContactList.xaml?selectedGroup=" + MainListBox.SelectedIndex, UriKind.Relative));  
  16.          MainListBox.SelectedIndex = -1;  
  17.       }  
  18.       private void MainPage_Loaded(object sender, RoutedEventArgs e)  
  19.       {  
  20.          if (!App.ViewModel.IsDataLoaded)  
  21.          {  
  22.             App.ViewModel.LoadData();  
  23.          }  
  24.       }  
  25.    }  

首先,在MainPage類的構造函數中,我們把DataContext屬性綁定到App.ViewModel。這一點很重要,也展示了整個系統的用戶描述層是如何實現的。

接下來,讓我們來分析一下MainPage_Loaded方法-每次示例頁面加載時都調用這個方法。預先檢查一下是否有必要再次加載視圖模型數據是一個很好的設計習慣。

***一點值得注意的是ListBox控件的SelectionChanged事件處理程序。在這個方法中,我們首先判斷用戶是否點擊了ListBox控件中的項目之一。如果沒有選中某個項目,即可返回;否則,我們把當前用戶導航到另一個網頁ContactList.xaml,以顯示對應于所選組對應的聯系人信息。注意,在頁面ContactList.xaml的OnNavigatedTo事件處理器中我們傳遞進參數selectedGroup。

至于頁面ContactList.xaml,有點復雜,但仍然很容易理解。首先,讓我們來看一下這個頁面的XAML標記代碼的情況。

列表7: 頁面ContactList.xaml的XAML標記代碼

  1. <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  2.     <ListBox x:Name="MainListBox" Margin="0,0,-12,0" > 
  3.         <ListBox.ItemTemplate> 
  4.             <DataTemplate> 
  5.                 <StackPanel Margin="0,0,0,17" Width="432"> 
  6.                     <TextBlock Text="{Binding GroupId}" TextWrapping="Wrap" 
  7.  
  8. Style="{StaticResource PhoneTextExtraLargeStyle}"/> 
  9.                     <TextBlock Text="{Binding Id}" TextWrapping="Wrap" Margin="12,-6,12,0" 
  10.  
  11. Style="{StaticResource PhoneTextSubtleStyle}"/> 
  12.                     <TextBlock Text="{Binding Name}" TextWrapping="Wrap" 
  13.  
  14. Style="{StaticResource PhoneTextExtraLargeStyle}"/> 
  15.                     <TextBlock Text="{Binding Email}" TextWrapping="Wrap" Margin="12,-  
  16.  
  17. 6,12,0" Style="{StaticResource PhoneTextSubtleStyle}"/> 
  18. <Image Source="{Binding ThumbNail,Converter={StaticResource  
  19.  
  20. ImageConverter1}}" /> 
  21.                 </StackPanel> 
  22.             </DataTemplate> 
  23.         </ListBox.ItemTemplate> 
  24.     </ListBox> 
  25. </Grid> 

為了簡單起見,我們還利用一個ListBox控件來展示聯系人信息。同時,我們也使用了典型的Silverlight數據綁定技術??傮w來看,上面代碼中只有一點值得注意,即圖像數據的顯示問題。為此,代碼中使用了一個自定義的類型轉換器。

列表8: 自定義的類型轉換器代碼

  1. public class imageUrlConverter : IValueConverter  
  2. {  
  3.    public object Convert(object value, Type targetType, object parameter,  
  4.    System.Globalization.CultureInfo culture)  
  5.    {  
  6.       if (value == null || parameter == null)  
  7.       {  
  8.          return value;  
  9.       }  
  10.       return new BitmapImage(new Uri((string)value, UriKind.RelativeOrAbsolute));  
  11.    }  
  12.    public object ConvertBack(object value, Type targetType, object parameter,  
  13.    System.Globalization.CultureInfo culture)  
  14.    {  
  15.       throw new NotImplementedException();  
  16.    }  

注意,在本示例實現方案中,在構建聯系人Contact的實例時,我們只持有在ThumbNail屬性中存儲的聯系人相關縮略圖的路徑信息。上面轉換器的關鍵在于Convert方法。在這個方法中,我們通過圖片路徑返回對應于縮略圖的BitmapImage實例。然后,我們將它設置為圖像控件的Source屬性。

至于頁面ContactList.xaml后臺代碼的實現就很簡單了,如下所示。

列表9: 頁面ContactList.xaml后臺代碼的實現

  1. protected override void OnNavigatedTo(NavigationEventArgs e)  
  2. {  
  3.    string selectedGroup = "";  
  4.    if (NavigationContext.QueryString.TryGetValue("selectedGroup"out selectedGroup))  
  5.    {  
  6.       int iGroup = int.Parse(selectedGroup);  
  7.       // Query from Database by key  
  8.       var contactList =from key in 
  9.       App.Database.Query().Where(  
  10.          x => x.LazyValue.Value.GroupId == iGroup + 1).ToList() select key.LazyValue.Value;  
  11.       MainListBox.ItemsSource=contactList;  
  12.    }  

OnNavigatedTo方法是Silverlight for WP7中的基本導航方法,不必再贅述了。在上面代碼中,一旦我們接收下selectedGroup參數,我們即使用它來創建一個標準的Sterling查詢語句。注意,要想全面領會這里的查詢語句,你應該先知道LazyValue在Sterling使用中所起的重要作用。***,我們把查詢結果綁定到ListBox控件的ItemsSource屬性。這就是全部!

#p#

四、總結

在本系列文章中,我們只是初步介紹了Sterling這款開源的面向對象嵌入式數據庫在Silverlight for Windows Phone 7中的基本應用思路和操作技巧。很顯然,如果讀者以前未曾有過面向對象數據庫方面的知識,你會感覺到Sterling的實現架構有些陌生。然而,如果您已經有扎實的C#面向對象和LINQ to Object基礎,那么,快速入門Sterling也不是什么難事。當然,不同于傳統的關系數據庫,在使用Sterling前,你***預先掌握一些面向對象程序設計技術,特別是掌握一些面向對象的數據庫理論。隨著Sterling在你心中不斷扎根,你會發現Sterling是一個相當不錯的工具-輕量級而且高效率,非常適合Windows Phone 7數據驅動應用程序的開發。實際上,本文介紹的只不過是觸及了Sterling的一點皮毛,還有更多更好的東西等著您自己去深入挖掘。

【編輯推薦】

  1. 為您介紹幾款開源的數據挖掘工具
  2. 告訴你如何解決MySQL server has gone away問題
  3. 數據庫中分組字符串相加
  4. SQL點滴之收集SQL Server線程等待信息
  5. 數據庫的性能已成重多廠商關注的焦點


 

責任編輯:艾婧 來源: it168
相關推薦

2011-05-18 10:21:53

SQLite

2011-05-18 09:30:16

SQLite

2011-02-28 10:42:14

Windows Pho微軟

2011-05-12 13:03:36

WP7數據庫選擇

2011-03-29 13:03:59

IronRubyWindows Pho.NET

2011-04-27 09:58:56

Windows PhoLBS微軟

2010-09-03 08:57:26

本地數據庫

2011-06-10 09:03:36

AndroidWindows Pho開發者

2011-05-10 08:53:46

iOSWindows Pho開發者

2011-08-19 09:09:01

AndroidWP7Windows Pho

2012-03-04 20:55:33

WP7

2012-07-06 09:26:13

Windows PhoWindows Pho

2012-01-01 19:33:19

2011-06-15 10:18:12

Windows PhoPerst

2013-06-17 14:10:08

WP7開發Windows Pho豆瓣電臺

2013-06-17 13:47:41

WP7開發Windows Pho文本框水印控件

2011-09-22 14:20:10

雷軍小米WP7

2011-07-28 09:26:18

MangoWindows Pho富士通

2011-03-08 10:26:45

Windows Pho諾基亞Qt

2012-06-21 09:07:22

微軟WP7WP8
點贊
收藏

51CTO技術棧公眾號

欧美裸身视频免费观看| 欧美午夜精品电影| 国产精品国产三级国产专区53| 日本一区二区免费在线观看| 妖精视频一区二区三区免费观看| 欧洲一区二区三区免费视频| 中文字幕精品在线播放| 外国精品视频在线观看 | 国产卡一卡二在线| 五十路在线视频| 精品在线一区二区三区| 69av成年福利视频| 亚洲二区在线播放| 久久综合欧美| 精品久久久久久久久久久久久久久 | 91精品免费视频| 在线观看精品国产| 久久久久久久久久久妇女| 亚洲黄色www| 免费黄频在线观看| 偷拍精品精品一区二区三区| 亚洲人午夜精品天堂一二香蕉| 精品在线视频一区二区| va视频在线观看| 日韩国产欧美视频| 午夜精品久久久久久久男人的天堂| 337人体粉嫩噜噜噜| 久久综合五月婷婷| 日韩精品一区二区三区中文不卡| 国产精品无码一本二本三本色| 后进极品白嫩翘臀在线播放| 中文字幕一区日韩精品欧美| 欧美亚洲国产免费| 亚洲毛片在线播放| 国产曰批免费观看久久久| 国产精品高清网站| 成年人免费高清视频| 欧美理论在线| 久久亚洲国产精品成人av秋霞| 亚洲码无人客一区二区三区| 欧美成人基地| 亚洲电影免费观看高清完整版在线 | 视频一区在线视频| 26uuu国产精品视频| 五月天婷婷网站| 欧美激情自拍| 欧美大码xxxx| 无码人妻精品一区二区三区夜夜嗨| 日韩精品中文字幕第1页| 国产小视频国产精品| 久久久无码人妻精品一区| 青青一区二区| 日韩av中文字幕在线免费观看| 特黄特色免费视频| 91精品久久久久久综合五月天| 日韩欧美成人一区二区| 肉色超薄丝袜脚交| 亚洲国产中文在线二区三区免| 欧美一区二区三区四区五区 | 日韩毛片一区| 欧洲精品一区二区| 小泽玛利亚视频在线观看| 99久久婷婷国产综合精品首页 | 狠狠干狠狠操视频| 日韩精品第二页| 91麻豆精品国产91久久久更新时间| 依人在线免费视频| 久久中文字幕一区二区| 日韩精品一区二区三区在线 | a在线视频观看| 亚洲精华液一区二区三区| 色综合色综合色综合| 热久久精品免费视频| 国产成人a视频高清在线观看| 欧美亚洲自拍偷拍| 亚洲色图欧美自拍| 高清欧美性猛交xxxx黑人猛| 日韩精品一区二区三区四区视频| 国产精品一区二区在线免费观看| 欧美绝顶高潮抽搐喷水合集| 亚洲色在线视频| 婷婷社区五月天| 欧美日一区二区在线观看| 97在线视频国产| 中文天堂在线资源| 国产凹凸在线观看一区二区| 精品欧美国产| 尤物网址在线观看| 亚洲午夜精品17c| 红桃av在线播放| 日本中文字幕视频一区| 精品三级在线看| 中文字幕免费高清| 欧美日韩日本国产亚洲在线| 欧美一区三区三区高中清蜜桃| 亚洲免费视频二区| 成人天堂资源www在线| 日本在线播放一区| 肉体视频在线| 在线观看免费视频综合| 精品人妻无码中文字幕18禁| 精品国内亚洲2022精品成人| 伊人亚洲福利一区二区三区| 精品少妇theporn| 日韩精品三区四区| 成人在线免费观看一区| 色天堂在线视频| 亚洲免费观看在线观看| 老熟妇仑乱视频一区二区| 香蕉免费一区二区三区在线观看| 国产亚洲日本欧美韩国| 国产一级特黄毛片| 久久97超碰色| 久久精彩视频| 欧洲一区二区三区| 欧美日韩一区久久| 懂色av粉嫩av蜜乳av| 欧美不卡视频| 国产欧美欧洲在线观看| 欧美一区二区三区少妇| 亚洲一区二区视频| 色婷婷激情视频| 久久国产成人精品| 日本韩国欧美精品大片卡二| www.色亚洲| 日韩久久一区二区| 国产 porn| 久久综合影院| 5566日本婷婷色中文字幕97| 亚洲AV无码国产精品午夜字幕 | 日韩经典在线观看| 国产成人啪免费观看软件| 一区二区三区我不卡| 国产另类xxxxhd高清| 亚洲精品电影网| 精品无码m3u8在线观看| 国产福利91精品一区| 青青草原国产免费| 91麻豆精品| 久久天天躁狠狠躁老女人| 一区二区视频免费观看| 欧美国产激情一区二区三区蜜月| av片中文字幕| 全球av集中精品导航福利| 久久久久久久久久国产| www.久久精品.com| 一级特黄大欧美久久久| 国产精品一级无码| 好看的亚洲午夜视频在线| 成人区精品一区二区| 男女视频在线| 欧美精品一区二区三区在线播放 | 在线日本成人| 国产亚洲欧美一区二区| 鲁鲁在线中文| 亚洲精品视频免费| 精品久久久久久久久久久国产字幕 | 亚洲xxxxx电影| 中文字幕在线三区| 精品久久一区二区| 狠狠躁夜夜躁人人爽天天高潮| 99免费精品在线| 日本www在线播放| 国产精品午夜一区二区三区| 国产极品精品在线观看| 9i精品一二三区| 69成人精品免费视频| 国产精品成人免费观看| 成人网在线播放| 久久精品香蕉视频| 99久久99热这里只有精品| 91亚洲精品一区| 8x8ⅹ拨牐拨牐拨牐在线观看| 亚洲精品乱码久久久久久按摩观| 黄色片中文字幕| 中文字幕一区二区不卡| 亚洲欧美综合视频| 亚洲尤物精选| 椎名由奈jux491在线播放 | 亚洲电影av在线| 精人妻无码一区二区三区| 国产精品久久久久一区二区三区 | 国产女人18毛片水真多| 亚洲图片欧美色图| 久久视频精品在线观看| 国产精品77777竹菊影视小说| 国产91xxx| 日韩不卡一区| 精品国产一二| 伊人久久大香线蕉综合影院首页| 欧美精品久久久久久久免费观看| 美女做暖暖视频免费在线观看全部网址91 | 日韩午夜在线视频| 日韩在线视频第一页| 欧洲在线/亚洲| 精品午夜福利视频| 国产精品网站在线| 亚洲一区二区三区四区av| 日本亚洲欧美天堂免费| a级免费在线观看| 成人一区而且| 国产精品有限公司| 国产第一亚洲| 奇米4444一区二区三区| a在线免费观看| 亚洲丝袜在线视频| 丰满少妇一级片| 精品视频在线免费观看| 69成人免费视频| 亚洲综合一区二区三区| 99自拍偷拍视频| 91蜜桃免费观看视频| 亚洲理论中文字幕| 青青草原综合久久大伊人精品优势 | 福利成人在线观看| 亚洲激情视频在线播放| 国产美女免费视频| 欧美色爱综合网| 亚洲天堂视频网站| 亚洲国产美国国产综合一区二区| 一级片黄色录像| wwww国产精品欧美| 亚洲麻豆一区二区三区| 国产精品99久久久久久久女警 | 男女超爽视频免费播放| 在线中文一区| 一区二区成人国产精品| 精品理论电影| 免费国产一区二区| 欧美日韩导航| 国产日韩亚洲精品| 91麻豆精品激情在线观看最新 | 国产精品福利一区二区三区| 亚洲AV无码国产成人久久| av电影天堂一区二区在线观看| 制服.丝袜.亚洲.中文.综合懂| 狠狠色丁香婷婷综合久久片| 国产精品人人爽人人爽| 老司机免费视频久久| 青青草原成人网| 在线视频精品| 少妇av一区二区三区无码| 精品999网站| 久久艹国产精品| 夜夜精品视频| 日本免费不卡一区二区| 在线亚洲欧美| 草草久久久无码国产专区| 国产深夜精品| 欧美激情成人网| 日韩精品三区四区| 91女神在线观看| 韩国三级在线一区| 深夜福利网站在线观看| 大尺度一区二区| 人体私拍套图hdxxxx| 91免费小视频| 亚洲自拍偷拍图| 中文字幕一区二区三区在线不卡| 特黄一区二区三区| 亚洲男人的天堂在线aⅴ视频| 欧美高清视频一区二区三区| 亚洲一区二区三区四区在线免费观看 | 国产精品免费久久久| 色成人综合网| 99在线看视频| 午夜先锋成人动漫在线| 日韩av电影免费在线| 日韩一区亚洲二区| 女女百合国产免费网站| av成人黄色| 午夜激情在线观看视频| 国产综合色在线| 人妻av一区二区| 国产亚洲欧美激情| 天天操夜夜操av| 亚洲国产视频直播| 极品国产91在线网站| 欧美精品久久一区二区三区| 亚洲风情第一页| 亚洲色图50p| www在线视频| 2018国产精品视频| 免费日韩成人| 精品国产一区二区三区四区vr| 国产毛片一区二区三区| 特级黄色录像片| 一区二区毛片| www.成年人| 91视频精品在这里| 日本中文在线视频| 婷婷国产v国产偷v亚洲高清| 中文字字幕在线中文乱码| 亚洲国产日韩精品在线| 午夜在线视频| 91av在线播放| 精品国产不卡一区二区| 免费看成人午夜电影| 午夜精品亚洲| 污视频免费在线观看网站| 成人免费视频app| 一本在线免费视频| 懂色av中文一区二区三区天美| 97视频免费在线| 亚洲男人第一网站| 性国产高清在线观看| 国产精品久久久久久久9999 | 日韩不卡视频在线观看| 国产高清一区二区三区| 久久在线电影| 免费激情视频在线观看| 成人性生交大片免费| 中日韩一级黄色片| 欧美日韩中文字幕| 亚洲第一天堂网| 久热爱精品视频线路一| 成人做爰免费视频免费看| 精品久久sese| 欧美日韩午夜| 四虎成人在线播放| 国产精品美女久久久久久久久| 黄色在线观看国产| 亚洲电影免费观看高清完整版在线观看 | 美女毛片一区二区三区四区| 欧美激情亚洲天堂| 精品一区二区免费| 超薄肉色丝袜一二三| 色欧美乱欧美15图片| 天堂中文字幕在线| 91极品视频在线| 福利电影一区| 日韩美女爱爱视频| 国产xxx精品视频大全| 欧美第一页在线观看| 欧美精品v国产精品v日韩精品| 国产在线视频资源| 国产成人精品一区二区三区| 五月综合久久| 女人扒开屁股爽桶30分钟| 99久久国产免费看| 91香蕉在线视频| 亚洲福利视频网| 美女视频在线免费| 美女黄毛**国产精品啪啪| 香蕉国产精品偷在线观看不卡| 欧美色图亚洲激情 | 97在线公开视频| 久久夜精品va视频免费观看| 日韩欧美激情| 一本二本三本亚洲码| 国产一区二区久久| 欧美精品xxxxx| 精品国精品国产尤物美女| 98色花堂精品视频在线观看| 国产亚洲欧美一区二区三区| 在线播放一区| 久久精品老司机| 在线免费视频一区二区| 在线观看免费版| 91香蕉国产在线观看| 亚洲福利专区| 国产又爽又黄无码无遮挡在线观看 | 黄色小视频大全| 东方欧美亚洲色图在线| 青青操免费在线视频| 一区二区三区精品99久久| 91精品在线免费视频| 日韩欧美精品免费| 2024国产精品| 亚洲无码久久久久| 欧美激情中文网| 香蕉视频一区| 五月天av在线播放| 亚洲精品成人a在线观看| 黄色三级网站在线观看| 国产99久久精品一区二区 夜夜躁日日躁 | 国产成人精品777777| 久久久久久久久99精品| 日本中文字幕在线| 日韩在线国产精品| 99国产精品久久一区二区三区| 久久人妻精品白浆国产 | 亚洲国产精品中文| 超碰这里只有精品| 亚洲色成人www永久在线观看 | 黄色aa久久| 视频一区视频二区视频三区视频四区国产 | 丁香六月色婷婷| 国产999在线观看| 欧美日韩国产色综合一二三四| 一区二区视频观看| 欧美高清精品3d| 自拍在线观看| 日韩不卡视频一区二区| 久久亚洲捆绑美女| 国产丝袜视频在线观看| 欧美壮男野外gaytube| 图片小说视频色综合| wwwwxxxx国产| 欧美电影精品一区二区|