久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

搭建MyBatis開(kāi)發(fā)環(huán)境及基本的CURD介紹

瀏覽:3日期:2023-10-23 12:25:52

一、MyBatis概述

首先就是之前Java web中的三層結(jié)構(gòu)

界面層: 和用戶打交道的, 接收用戶的請(qǐng)求參數(shù), 顯示處理結(jié)果的。(jsp ,html ,servlet)業(yè)務(wù)邏輯層: 接收了界面層傳遞的數(shù)據(jù),計(jì)算邏輯,調(diào)用數(shù)據(jù)庫(kù),獲取數(shù)據(jù)數(shù)據(jù)訪問(wèn)層: 就是訪問(wèn)數(shù)據(jù)庫(kù), 執(zhí)行對(duì)數(shù)據(jù)的查詢,修改,刪除等等的

三層中對(duì)應(yīng)的包:

界面層: controller包 (servlet)業(yè)務(wù)邏輯層: service 包(XXXService類(lèi))數(shù)據(jù)訪問(wèn)層: dao包(XXXDao類(lèi))

三層中類(lèi)的交互

用戶使用界面層--> 業(yè)務(wù)邏輯層--->數(shù)據(jù)訪問(wèn)層(持久層)-->數(shù)據(jù)庫(kù)(mysql)

三層對(duì)應(yīng)的處理框架

界面層---servlet---springmvc(框架) 業(yè)務(wù)邏輯層---service類(lèi)--spring(框架) 數(shù)據(jù)訪問(wèn)層---dao類(lèi)--mybatis(框架)

1. MyBatis 解決的主要問(wèn)題

減輕使用 JDBC 的復(fù)雜性,不用編寫(xiě)重復(fù)的創(chuàng)建 Connetion , Statement ; 不用編寫(xiě)關(guān)閉資源代碼。直接使用 java 對(duì)象,表示結(jié)果數(shù)據(jù)。讓開(kāi)發(fā)者專(zhuān)注 SQL 的處理。 其他分心的工作由 MyBatis 代勞

總的來(lái)說(shuō),mybatis就是增強(qiáng)版的JDBC

二、快速開(kāi)始一個(gè) MyBatis

首先就是搭建MyBatis的環(huán)境

1. 創(chuàng)建mysql數(shù)據(jù)庫(kù)和表

數(shù)據(jù)庫(kù)名:ssm,表名:student

搭建MyBatis開(kāi)發(fā)環(huán)境及基本的CURD介紹

2. 創(chuàng)建maven工程

這個(gè)就不詳細(xì)的說(shuō)了,可以看之前寫(xiě)的文章

https://www.jb51.net/article/189570.htm

3. 在pom.xml文件中添加信息

主要就是mybatis依賴,和mysql驅(qū)動(dòng)

還有就是在build標(biāo)簽里添加maven插件,方便之后使用

<?xml version='1.0' encoding='UTF-8'?><project xmlns='http://maven.apache.org/POM/4.0.0' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd'> <modelVersion>4.0.0</modelVersion> <groupId>com.md</groupId> <artifactId>01-hello-mybatis</artifactId> <version>1.0-SNAPSHOT</version> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> <!--mybatis依賴--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.1</version> </dependency> <!--mysql驅(qū)動(dòng)--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.9</version> </dependency> </dependencies> <build> <resources> <resource> <directory>src/main/java</directory><!--所在的目錄--> <includes><!--包括目錄下的.properties,.xml 文件都會(huì)掃描到--> <include>**/*.properties</include> <include>**/*.xml</include> </includes> <filtering>false</filtering> </resource> </resources> </build></project>

4. 編寫(xiě)對(duì)應(yīng)的實(shí)體類(lèi)

創(chuàng)建包c(diǎn)om.md.domain,創(chuàng)建Student類(lèi)

package com.md.domain;/** * @author MD * @create 2020-08-05 9:04 */// 和數(shù)據(jù)庫(kù)的表名一樣,public class Student { // 定義屬性,屬性名和列名一致 private Integer id; private String name; private String email; private Integer age; public Student() { } public Student(Integer id, String name, String email, Integer age) { this.id = id; this.name = name; this.email = email; this.age = age; }// 對(duì)應(yīng)的set和get方法以及toString() }

5. 編寫(xiě)Dao接口:StudentDao

創(chuàng)建包:com.md.dao

package com.md.dao;import com.md.domain.Student;import java.util.List;/** * @author MD * @create 2020-08-05 9:07 */public interface StudentDao { // 查詢Student表中所有數(shù)據(jù) public List<Student> selectStudents();}

6. 編寫(xiě) Dao 接口 Mapper 映射文件 StudentDao.xml

注意:

在接口所在的包:com.md.dao里創(chuàng)建文件 StudentDao.xml這個(gè)映射文件的名稱要和接口的名稱一樣

特別注意里面寫(xiě)的備注信息

<?xml version='1.0' encoding='UTF-8' ?><!--指定的約束文件,mybatis-3-mapper.dtd是約束文件的名稱,擴(kuò)展名是dtd約束文件的作用:限制、檢查當(dāng)前文件中出現(xiàn)的標(biāo)簽,屬性必須符號(hào)mybatis的要求--><!DOCTYPE mapper PUBLIC '-//mybatis.org//DTD Mapper 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-mapper.dtd'><!--mapper:是當(dāng)前文件的根標(biāo)簽namespace :必須有值,自定義的唯一字符串,推薦使用: dao 接口的全限定名稱--><mapper namespace='com.md.dao.StudentDao'> <!-- <select>: 查詢數(shù)據(jù), 標(biāo)簽中必須是 select 語(yǔ)句 id: sql 語(yǔ)句的自定義名稱,推薦使用 dao 接口中方法名稱, 使用名稱表示要執(zhí)行的 sql 語(yǔ)句 resultType: 查詢語(yǔ)句的返回結(jié)果數(shù)據(jù)類(lèi)型,使用全限定類(lèi)名 --> <select resultType='com.md.domain.Student'> <!-- 要執(zhí)行的 sql 語(yǔ)句 --> select id,name,email,age from student </select> <!-- <update>:表示更新數(shù)據(jù)庫(kù)的操作,里面寫(xiě)的是update sql語(yǔ)句 <insert>: <delete>: --></mapper>

7. 創(chuàng)建 MyBatis 主配置文件

注意:

在項(xiàng)目 src/main 下創(chuàng)建 resources 目錄,設(shè)置 resources 目錄為 resources root 創(chuàng)建主配置文件:名稱為 mybatis.xml

特別注意里面寫(xiě)的備注信息

<?xml version='1.0' encoding='UTF-8' ?><!--mybatis的主配置文件,上面還是約束文件的說(shuō)明--><!DOCTYPE configuration PUBLIC '-//mybatis.org//DTD Config 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-config.dtd'><!--根標(biāo)簽 --><configuration> <!-- 配置 mybatis 環(huán)境 數(shù)據(jù)庫(kù)的連接信息,default:必須和某個(gè)environment的id值一樣 ,告訴mybatis使用那個(gè)數(shù)據(jù)庫(kù)的連接信息,也就是訪問(wèn)那個(gè)數(shù)據(jù)庫(kù) --> <environments default='mysql'> <!-- 一個(gè)數(shù)據(jù)庫(kù)的配置信息 id: 數(shù)據(jù)源的名稱,可以自定義 --> <environment id='mysql'> <!-- 配置事務(wù)類(lèi)型:使用 JDBC 事務(wù)(使用 Connection 的提交和回滾) --> <transactionManager type='JDBC'/> <!-- 數(shù)據(jù)源 dataSource :創(chuàng)建數(shù)據(jù)庫(kù) Connection 對(duì)象 type: POOLED 使用數(shù)據(jù)庫(kù)的連接池 --> <dataSource type='POOLED'> <!-- 連接數(shù)據(jù)庫(kù)的四個(gè)要素,是固定的 --> <property name='driver' value='com.mysql.jdbc.Driver'/> <property name='url' value='jdbc:mysql://localhost:3306/ssm'/> <property name='username' value='root'/> <property name='password' value='123456'/> </dataSource> </environment> </environments> <!--sql映射文件的位置--> <mappers> <!-- 告訴 mybatis 要執(zhí)行的 sql 語(yǔ)句的位置 一個(gè)標(biāo)簽指定一個(gè)文件的位置 --> <mapper resource='com/md/dao/StudentDao.xml'/> </mappers></configuration>

如果是高版本的mysql,中文亂碼可以使用下面的

支持中文的 urljdbc:mysql://localhost:3306/ssm?useUnicode=true&characterEncoding=utf-8

基本就是如下的結(jié)構(gòu)

搭建MyBatis開(kāi)發(fā)環(huán)境及基本的CURD介紹

搭建MyBatis開(kāi)發(fā)環(huán)境及基本的CURD介紹

8. 創(chuàng)建測(cè)試類(lèi) TestMybatis

在src/test/java/com/md/ 創(chuàng)建TestMybatis

特別注意里面寫(xiě)的備注信息

主要關(guān)心第六步和第七步,前面的都是一樣的,后面直接封裝方法

package com.md;import com.md.domain.Student;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.Test;import java.io.IOException;import java.io.InputStream;import java.util.List;/** * @author MD * @create 2020-08-05 10:27 */public class TestMybatis { // 測(cè)試方法 @Test public void testSelect() throws IOException { // 訪問(wèn)mybatis讀取student數(shù)據(jù) //1.定義mybatis主配置文件的名稱, 從類(lèi)路徑的根開(kāi)始(target/clasess),編譯之后的目錄 String config = 'mybatis.xml'; //2.讀取這個(gè)config表示的文件 InputStream in = Resources.getResourceAsStream(config); //3.創(chuàng)建了SqlSessionFactoryBuilder對(duì)象 SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); //4.創(chuàng)建SqlSessionFactory對(duì)象 SqlSessionFactory factory = builder.build(in); //5.獲取SqlSession對(duì)象,從SqlSessionFactory中獲取SqlSession SqlSession sqlSession = factory.openSession(); //6.【重要】指定要執(zhí)行的sql語(yǔ)句的標(biāo)識(shí)。 sql映射文件中的namespace + '.' + 標(biāo)簽的id值// String sqlId = 'com.md.dao.StudentDao'+'.'+'selectStudents'; String sqlId = 'com.md.dao.StudentDao.selectStudents'; //7.【重要】執(zhí)行sql語(yǔ)句,通過(guò)sqlId找到語(yǔ)句 List<Student> studentList = sqlSession.selectList(sqlId); //8.輸出結(jié)果 studentList.forEach( stu -> System.out.println(stu)); //9.關(guān)閉SqlSession對(duì)象 sqlSession.close(); }}

如果運(yùn)行找不到mybatis.xml文件,先檢查是否在pom.xml中配置下面的信息沒(méi),

在pom.xml下的build標(biāo)簽中

<resources> <resource> <directory>src/main/java</directory><!--所在的目錄--> <includes><!--包括目錄下的.properties,.xml 文件都會(huì)掃描到--> <include>**/*.properties</include> <include>**/*.xml</include> </includes> <filtering>false</filtering> </resource></resources>

不行的話就重啟項(xiàng)目,通常就可以解決問(wèn)題

9. 配置日志功能

mybatis.xml 文件加入日志配置,可以在控制臺(tái)輸出執(zhí)行的 sql 語(yǔ)句和參數(shù)

在根標(biāo)簽里面添加

<settings> <!-- 設(shè)置mybatis的輸出日志--> <setting name='logImpl' value='STDOUT_LOGGING' /> </settings>

然后運(yùn)行項(xiàng)目,就可以在控制臺(tái)看到輸出了

三、總結(jié)

實(shí)現(xiàn)步驟

新建一個(gè)student表 加入maven的mybatis坐標(biāo),以及mysql驅(qū)動(dòng)的坐標(biāo),看pom.xml文件中的信息 創(chuàng)建實(shí)體類(lèi),Student,保存表中一行的數(shù)據(jù) 創(chuàng)建持久層的dao接口,定義操作數(shù)據(jù)庫(kù)的方法 創(chuàng)建一個(gè)mybatis使用的配置文件,叫做sql映射文件(mapper文件),一般一個(gè)表一個(gè)sql的映射文件,是xml文件,并且這個(gè)文件是在接口所在的目錄,文件名和接口名一致 創(chuàng)建mybatis的主配置文件,一個(gè)項(xiàng)目就一個(gè)主配置文件,主配置文件提供了數(shù)據(jù)庫(kù)的連接信息和sql映射文件的位置信息 創(chuàng)建測(cè)試類(lèi),使用mybatis訪問(wèn)數(shù)據(jù)庫(kù)

四、insert

1. StudentDao 接口中增加方法

// 插入方法 public int insertStudent(Student student);

2. StudentDao.xml 加入 sql 語(yǔ)句

<!-- 插入的時(shí)候要注意占位符,就是你傳入對(duì)象的屬性值--> <insert > insert into student values(#{id},#{name},#{email},#{age}) </insert>

3. 增加測(cè)試方法

前面的都一樣,主要就是第六步之后的

package com.md;public class TestMybatis { // 測(cè)試方法 @Test public void testInsert() throws IOException { String config = 'mybatis.xml'; InputStream in = Resources.getResourceAsStream(config); SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); SqlSessionFactory factory = builder.build(in); SqlSession sqlSession = factory.openSession(); //6.【重要】指定要執(zhí)行的sql語(yǔ)句的標(biāo)識(shí)。 sql映射文件中的namespace + '.' + 標(biāo)簽的id值// String sqlId = 'com.md.dao.StudentDao'+'.'+'selectStudents'; String sqlId = 'com.md.dao.StudentDao.insertStudent'; //7.【重要】執(zhí)行sql語(yǔ)句,通過(guò)sqlId找到語(yǔ)句 // 第一個(gè)參數(shù)是執(zhí)行的sql語(yǔ)句,第二個(gè)是對(duì)象 int i = sqlSession.insert(sqlId,new Student(1004,'劉桑','ls@qq.com',18)); // 需要注意,mybatis默認(rèn)不是自動(dòng)提交事務(wù),所以在寫(xiě)完insert、update、delete之后,手動(dòng)的提交事務(wù) sqlSession.commit(); //8.輸出結(jié)果 System.out.println('執(zhí)行insert影響的行數(shù):'+i); //9.關(guān)閉SqlSession對(duì)象 sqlSession.close(); }}

需要注意,mybatis默認(rèn)不是自動(dòng)提交事務(wù),所以在寫(xiě)完insert、update、delete之后,手動(dòng)的提交事務(wù)

五、update

和上面的都差不多,就直接寫(xiě)主要的步驟

1. StudentDao 接口中增加方法

int updateStudent(Student student);

2. StudentDao.xml 增加 sql 語(yǔ)句

<update id='updateStudent'>update student set age = #{age} where id=#{id}</update>

3. 增加測(cè)試方法

//5. 創(chuàng)建保存數(shù)據(jù)的對(duì)象Student student = new Student();student.setId(1005);// 要修改的 idstudent.setAge(30); // 要修改的年齡值//6. 執(zhí)行 更新 updateint rows = session.update('com.bjpowernode.dao.StudentDao.updateStudent',student);//7. 提交事務(wù)session.commit();System.out.println(' 修改記錄的行數(shù):'+rows);//8. 關(guān)閉 SqlSessionsession.close();

六、delete

1. StudentDao 接口中增加方法

int deleteStudent(int id);

2. StudentDao.xml 增加 sql 語(yǔ)句

<delete id='deleteStudent'>delete from student where id=#{studentId}</delete>

3. 增加測(cè)試方法

//5. 刪除的 idint id = 1001;//6. 執(zhí)行刪除 deleteint rows = session.delete('com.bjpowernode.dao.StudentDao.deleteStudent',id);//7. 提交事務(wù)session.commit();System.out.println(' 修改記錄的行數(shù):'+rows);//8. 關(guān)閉 SqlSessionsession.close();

總結(jié)

到此這篇關(guān)于搭建MyBatis開(kāi)發(fā)環(huán)境及基本的CURD的文章就介紹到這了,更多相關(guān)搭建MyBatis開(kāi)發(fā)環(huán)境及基本的CURD內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章:
主站蜘蛛池模板: 日韩欧美在线免费观看 | 精品在线一区二区三区 | av中文字幕在线播放 | 亚洲一区视频在线 | 欧美日韩精品一区二区三区在线观看 | jjzz18国产 | 黄网站免费在线观看 | 欧美电影一区 | 色偷偷噜噜噜亚洲男人 | 日韩欧美一级精品久久 | 欧美一级片aaa | 国产精品极品美女在线观看免费 | 丝袜 亚洲 另类 欧美 综合 | 日本成人福利视频 | 亚洲欧美在线一区 | 久久mm| 男人天堂a | 久久免费视频国产 | 欧美精品久久久 | 污片在线免费看 | 日韩视频一区二区三区四区 | 欧洲美女性开放视频 | aaa在线| www.国产 | 国产精品日本欧美一区二区三区 | h片在线免费观看 | 欧美日韩国产一区二区三区 | 蜜桃av一区 | 羞羞视频免费观看入口 | 一区二区免费视频 | 欧美在线视频不卡 | 黄色片网站在线看 | 欧美精品欧美精品系列 | 狠狠av | 日韩手机专区 | 天堂综合网 | 亚洲一区二区三区在线免费观看 | 日韩av中文在线 | 日日撸| 国产一区二区在线观看视频 | 蜜臀网 | 欧美精品日韩 | 欧美成人一区二区三区片免费 | 精品国产一区二区三区在线观看 | 国产操片 | 狠狠色狠狠色综合网 | 久久精品国产亚卅av嘿嘿 | 日韩在线视频观看 | 日b片| 亚洲一区视频 | 国产精品久久一区 | 亚洲欧美网站 | 精品无码久久久久国产 | 黄色片免费看 | 国产精品一区二区久久 | 久久成人av | 91在线视频在线 | 免费的色网站 | 久草 在线 | 黑人巨大精品欧美一区二区免费 | 精品一区二区三区四区视频 | 四虎影院在线看 | 欧美 日韩 国产 在线 | 国产综合精品一区二区三区 | 91精品国产乱码久 | 精品一区二区三区四区视频 | 国产精品大片 | 激情五月综合 | 日本xxww视频免费 | 日韩av片在线免费观看 | 日韩一区二区精品视频 | 中文字幕日韩欧美一区二区三区 | 成人v片 | 久热中文 | 欧美精品福利视频 | 噜噜噜在线视频 | 草草视频在线免费观看 | 精品日韩视频 | 97av在线| 毛片在线视频 | 免费看的黄网站 | 精品在线看 | 欧美日韩不卡合集视频 | 久久国产一区二区 | 欧美一级全黄 | jizz国产免费 | 国产 欧美 日韩 一区 | 欧美日韩在线一区二区 | 精品乱码久久久 | 国产人免费人成免费视频 | 一级毛片电影 | 精品久久久久久久久久久久 | 无码一区二区三区视频 | 免费黄色大片 | 91午夜精品 | 超碰最新网址 | 日韩三级电影在线免费观看 | 国产欧精精久久久久久久 | av片在线观看 | 亚洲精品亚洲人成人网 | 色网在线观看 | 中国大陆高清aⅴ毛片 | 成人久久18免费观看 | 久久国产精品视频观看 | 国产欧美日韩综合精品一区二区 | 精品国产精品 | 欧洲亚洲精品久久久久 | 精品久久久久久久久久久久 | 欧美日韩国产中文字幕 | 超碰8| 国产精品夜夜春夜夜爽久久电影 | 久久9色| 中文字幕99 | 香蕉综合久久 | 日韩视频一区二区 | 91在线精品视频 | 欧美日本一区二区三区 | 欧美日韩电影一区二区 | 日韩欧美在线一区 | 欧美9999 | 在线视频一区二区三区 | 91精品国产综合久久久久久蜜月 | 亚洲国产精品一区 | 国产精品www | 亚洲久草 | 在线精品一区 | 久久久久综合 | 欧美一区二区三区免费 | 日韩第一页 | 精品国偷自产国产一区 | 最新免费av网站 | 国产精品视频99 | 亚洲一区二区三区四区在线观看 | 国产精品视频网站 | 国产精品美女久久久久久久久久久 | 欧美黑人一级毛片 | 国产精品一区二区三区在线 | 中文字幕 在线观看 | 久久亚洲一区二区三区四区 | 婷婷成人免费视频 | 久久天堂热 | 日本久久久久久 | 成av人片在线观看www | 午夜视频黄 | 精品国产乱码久久久久久密桃99 | 午夜视频大全 | 午夜电影合集 | 在线观看毛片视频 | 久草视频在线播放 | 欧美 日韩 国产 一区 | 亚洲毛片 | 精品国产欧美一区二区三区成人 | 欧美日韩亚洲高清 | 在线视频亚洲 | 亚洲中午字幕 | 私人毛片免费高清视频 | 亚洲免费在线视频 | 欧美在线视频一区二区 | 成人爽a毛片一区二区免费 亚洲自拍偷拍精品 | 国产丝袜一区二区三区免费视频 | 国产免费一区 | 国产97久久| 成人欧美一区二区三区黑人孕妇 | 久久成人精品 | 国产人久久人人人人爽 | 国产午夜精品福利 | 国产午夜精品一区二区三区 | 欧美亚洲另类丝袜综合网动图 | 国产精品久久久久免费 | 久久久久国产一级毛片 | www.黄色片视频 | 精品国产第一国产综合精品 | 精品国产乱码久久久久久88av | 国产h视频在线观看 | 欧美日韩国产一级片 | 在线中文字幕观看 | 国产亚洲精品久久久闺蜜 | 天天综合网7799精品 | 成人在线视频播放 | jizzjizzjizz亚洲女 | 欧美成人综合 | 色香阁99久久精品久久久 | 国产精品一区久久久久 | 日韩在线一区二区三区 | 国产精品69毛片高清亚洲 | 日韩欧美一级精品久久 | 中文字幕一区二区三区四区 | 91精品国产综合久久福利软件 | 免费一级欧美在线观看视频 | 国产精品美女久久久久久免费 | 国产 日韩 欧美 中文 在线播放 | 欧美一级在线观看 | 久久久久国产精品 | www.日韩在线观看 | 亚洲色图综合 | 91精品国产综合久久久久久丝袜 | 午夜影视剧场 | 成人av播放| 夜夜av| 国产精品第一国产精品 | 婷婷激情综合 | 亚洲精品一二三区 | www.视频在线观看 | 男人的天堂久久精品 | 日韩一级 | 99视频免费| 久久99精品国产91久久来源 | 免费观看黄色大片 | 成人免费观看视频 | 成人在线视频网站 | 色综合视频| 视色视频在线观看 | 中文字幕精品一区久久久久 | 日韩精品久久久久久 | 国产免费一区 | 91免费看电影 | 久久草在线视频 | 一色视频 | 成人精品鲁一区一区二区 | 免费在线观看毛片网站 | 欧美在线一二三 | 高清一区二区 | 美日韩精品| 午夜久久久 | 伊人网网站 | 亚洲精品一区二区三区 | 91成人免费看片 | 国产视频一视频二 | 欧美极品一区二区三区 | www中文字幕 | 美日韩精品视频 | 欧美精品一区二区三区四区 | 日本午夜精品 | 亚洲性人人天天夜夜摸 | 久久青| 九九亚洲 | 91精品国产综合久久久久久丝袜 | 久久精品亚洲一区 | 亚洲欧洲av在线 | 日韩精品成人 | 黄色在线免费观看 | 国产精品成人3p一区二区三区 | 国产片侵犯亲女视频播放 | 国产精品久久久久久久久久久久久 | 国产1级片 | 一区二区免费视频观看 | 一色一黄视频 | 精品亚洲一区二区 | 毛片天堂 | av中文字幕网 | 日韩在线一区二区 | 久久精品国产视频 | 韩国精品一区二区 | 久久国产精品99久久久久久老狼 | 91久久久久久久久 | 久草天堂 | 欧美日韩国产在线看 | 亚洲视频在线看 | 天堂精品久久 | 亚洲精品一 | 午夜国产在线 | 欧美日韩国产不卡 | 激情小视频网站 | 美女国产精品 | 国产视频网 | 欧美在线观看免费观看视频 | 国产综合精品一区二区三区 | 人操人人| 五月婷婷综合激情网 | 久久777| 日韩理论在线 | 国产精品一区二区视频 | 69性欧美高清影院 | 日韩精品www | 久久一二区 | av一区二区三区四区 | 男人电影天堂 | 国产婷婷色一区二区三区 | 91视频网 | 色综合激情| 久久九 | 国产有码| 久久久精品 | 国产成人一区二区 | 午夜影视 | 一级a性色生活片久久毛片波多野 | 福利91 | 亚洲午夜精品一区二区三区 | 久久精品国产清自在天天线 | 成人精品免费视频 | 欧美亚洲国产一区 | 在线欧美日韩 | 日本69视频 | 精品国产一区二区三区久久久蜜月 | 国产精品久久久久久久久免费软件 | 亚洲aⅴ | 成人av综合 | 久久亚洲天堂 | 亚洲二区视频 | 2019国产精品 | 免费国产视频在线观看 | 天天草夜夜 | 亚洲一区二区三区精品视频 | 一区小视频 | 黄色永久网站 | 97久久久| 日本高清视频一区二区三区 | 欧洲毛片 | 中国妞xxxhd露脸偷拍视频 | av在线一区二区三区 | 日韩精品中文字幕在线播放 | 国产激情在线视频 | 黄色av网站在线观看 | 欧美在线视频三区 | 5060毛片| 国产精品毛片久久久久久久 | 日本一区二区不卡 | 日韩欧美国产一区二区三区 | 日韩免费在线观看视频 | 欧美福利一区 | 久久精品| 成人福利| 国产精品无码久久久久 | 日韩中文字幕一区二区高清99 | 三级黄色视频毛片 | 久久男人的天堂 | 人人射人人舔 | 日本不卡一区二区三区在线观看 | 欧美一级片毛片免费观看视频 | 中文字幕在线观看网站 | 欧美精品第一页 | 国产超碰人人模人人爽人人添 | 美女黄视频网站 | 欧美日韩精品久久久 | 亚洲乱码国产乱码精品精的特点 | 欧美日韩精品在线 | 国产三级电影 | 国产高清在线精品 | 日日日操 | 国产精品视频专区 | 欧美精品在线免费观看 | 日本成人中文字幕 | 免费成人在线网站 | 日韩精品一区二区三区在线观看 | 国产美女在线观看 | 国产一区二区在线免费观看 | 国产精品久久天天躁 | 国产一级免费 | 欧美日韩在线第一页 | 欧美日韩欧美日韩 | 81精品国产乱码久久久久久 | 免费黄色看片 | 久久成人免费视频 | 天天插天天操天天干 | www.精品 | 中文字幕一区二区三区四区不卡 | 天堂福利影院 | 在线日韩欧美 | 欧美极品视频 | 亚洲国产成人精品女人 | 欧美一区二区三区在线视频 | 中文在线视频 | 中文字幕亚洲一区二区三区 | 波多野结衣电影一区 | 啪啪毛片 | a√毛片| 在线99热 | 日本一二三区视频 | 国产精品99久久久久久久vr | 亚洲特级 | a视频在线观看免费 | 精品国产乱码久久久久久影片 | 狠狠操精品视频 | 亚洲成人高清 | 成人免费淫片aa视频免费 | 国产精品久久国产精品 | 国产视频2021| 日韩免费一级 | 免费成人在线网站 | 亚洲巨乳自拍在线视频 | 成年人黄色一级毛片 | 91高清在线| 成人精品久久久 | 国产成人高清在线 | 国产一级片 | 91精品国产色综合久久不卡98口 | 成人激情视频免费观看 | 成年人视频在线观看免费 | 日本在线免费电影 | 99国内精品久久久久久久 | 日本欧美久久久久 | 婷婷色视频 | 欧美日韩免费一区二区三区 | 国产精品热 | 噜噜噜在线视频 | 天天爱爱网 | 99久久婷婷国产综合精品 | 国产免费国产 | 福利网址 | 精品国产髙清在线看国产毛片 | 久久黄网 | 香蕉久久久久久 | 亚洲精品久久 | 人人人艹 | 男女啪啪高清无遮挡 | 亚洲一区二区在线播放 | 福利网站在线观看 | 久草院线 | 亚洲性在线 | 99久久精品免费 | 久久中文视频 | 日本大人吃奶视频xxxx | 日韩中文字幕三区 | 伊人激情网| 亚洲天堂一区 | 日本狠狠干 | 精品九九| 午夜激情在线免费观看 | 日本精品中文字幕 | 日日骑夜夜操 | 亚洲免费网 | 热久久这里只有精品 | 免费亚洲成人 | 一区二区视频在线 | 国产伦精品久久久一区二区三区 | 亚洲免费视频在线 | 国产精品视频网站 | 亚洲精品成人免费 | 亚洲欧美日韩精品 | 久久在线播放 | 91精品国产乱码久久久久久 | 国产亚洲一区二区三区在线观看 | 精品久久网| 一级做a爰片性色毛片2021 | 亚洲动漫在线观看 | 午夜视频在线播放 | 日韩精品一区二区三区在线播放 | 久久久久久99 | 国产激情 | 亚洲一区二区国产 | 亚洲精品久久久 | 精品永久免费 | 国产精品高潮呻吟 | 欧美日韩国产在线 | 在线视频 亚洲 | 精品国产乱码久久久久久丨区2区 | 欧美一级二级三级视频 | 久久精品亚洲 | 日本成年人免费网站 | 在线a电影| 中文 日韩 欧美 | 日韩在线观看视频一区 | 国产日韩精品在线观看 | 欧美成在线观看 | 久久午夜影院 | 成人免费观看视频 | www亚洲一区| 欧美日韩国产综合网 | 久久久精品456亚洲影院 | 久久国产成人 | 国产精品美女久久久久久不卡 | 天天拍天天操 | 精品久久久久久久久久久院品网 | 色吊丝在线永久观看最新版本 | 农村妇女毛片精品久久久 | 日韩一区二区在线观看 | 成人精品在线视频 | 日韩精品91爱爱 | 久久精品亚洲精品国产欧美kt∨ | 国产精品美女视频免费观看软件 | 欧美日韩国产综合视频 | 欧美高清成人 | 久久久综合亚洲91久久98 | a在线免费观看 | 欧美日韩在线第一页 | 亚洲精品久久一区二区三区 | 91成人短视频在线观看 | 亚洲伊人久久综合 | 在线看片福利 | 久久久久久亚洲 | 欧美精品三区 | 91麻豆精品国产91久久久久久 | 欧美日韩精品一区 | 国产精品网站在线看 | 91免费国产| 国产成人福利在线 | 日韩三级av在线 | 四虎影院最新网站 | 全免一级毛片 | 成人av免费在线 | 色婷婷av一区二区三区大白胸 | 在线观看理论电影 | 日操| 日本精品免费在线观看 | 在线干| 日日碰碰| 一区二区三区不卡视频 | 亚洲精品免费在线观看 | 91极品国产| 亚洲成人免费 | 午夜免费福利影院 | 午夜精品影院 | 91麻豆产精品久久久久久 | 国产精品午夜电影 | av国产精品 | 欧美成人小视频 | 欧美另类专区 | a级在线免费视频 | 男人的天堂久久 | av在线免费观看网站 | 九九精品久久久 | 国产精品久久久久久久久免费桃花 | 日韩一区二区在线电影 | 伊人久色 | 成人二区 | 国产网站在线 | 国产精品久久久久久久久 | 亚洲国产精品成人 | 中文字幕不卡 | 欧美成人精品一区 | 欧美日韩中文字幕在线 | 韩国精品在线 | 国产免费看 | 欧美激情一区二区 | 天堂资源网 | 精品久久一区二区三区 | 午夜精品一区二区三区免费视频 | 久久久久久久久99精品 | 日日干日日操 | 色综合久久网 | 1区2区视频 | av网站免费 | 亚洲视频观看 | 在线h观看 | 欧洲精品在线观看 | 高清国产午夜精品久久久久久 | 欧美国产精品一区二区 | va在线 | 国产一区二区精品在线观看 | 亚洲日本韩国欧美 | 91成人一区 | 亚洲艹 | 亚洲成人久久久 | 国产日韩一区二区三区 | 欧美日韩在线免费 | 欧美一区二区在线播放 | 久久久久久国产精品mv | 一区二区三区亚洲 | 日本a在线 | 亚洲久草 | 国产在线精品一区二区三区 | 久久精品国产一区二区三区不卡 | 亚洲欧美中文日韩在线v日本 | 亚洲第一福利视频 | 国产精品原创av片国产免费 | 欧美一区二区三区视频在线观看 | 亚洲成人一区二区三区 | 欧美一区二区在线视频 | 在线视频a| 中国大陆高清aⅴ毛片 | 亚洲一区二区三区日韩 | 在线观看中文视频 | 精品美女在线 | 欧美亚洲国产一区二区三区 | 国产一区二区av | 欧美激情伊人 | 成人欧美 | 久久一| 国外成人在线视频网站 | 日本高清视频一区二区三区 | 91精品国产一区二区 | 亚洲午夜视频在线观看 | 欧美99| 日韩城人免费 | 精品欧美乱码久久久久久 | 欧洲另类二三四区 | 国产亚洲一区二区精品 | 99精品国产高清在线观看 | 青青草网 | 高清av网址 | 精品国产一区二区三区久久久久久 | 精品 99| 欧美在线a| 精品久久网 | 成人网av| 日韩一区二区在线播放 | 国产精品久久久久久久久久东京 | 国产综合亚洲精品一区二 | 最新av网址大全 | 一区二区三区欧美在线 | 国产在线看h | 一级毛片网 | 久久韩国| 国产精品久久免费视频在线 | 欧美亚洲一区 | 成人精品一区二区 | 欧美日一区二区 | 99成人在线视频 | 中文字幕日韩一区二区不卡 | www久久精品 | 亚洲精品一区中文字幕乱码 | 亚洲精品久久久久久久久久久 | 亚洲一区电影 | 欧美一区久久 | 久久一区二区精品 | 欧美综合久久 | 亚洲精品久久久久久一区二区 | 99精品欧美一区二区三区 | 日韩免费视频 | 国产美女精品人人做人人爽 | 天天爽天天操 | 国产视频9999| 水卜樱一区二区av | 嫩呦国产一区二区三区av | 国产中文字幕在线观看 |