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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

iBatis for net 框架使用

發布時間:2025/3/11 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iBatis for net 框架使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

介:ibatis?一詞來源于“internet”和“abatis”的組合,是一個由Clinton?Begin在2001年發起的開放源代碼項目,到后面發展的版本叫MyBatis但都是指的同一個東西。最初側重于密碼軟件的開發,現在是一個基于Java的持久層框架,漸漸的也把這種模式轉移到了net。相對NHibernate等“一站式”ORM解決方案而言,ibatis?是一種“半自動化”的ORM實現。

下載地址:http://code.google.com/p/mybatisnet/downloads/list?can=3?

本文開發Demo環境:IBatis.DataMapper.1.6.2.bin?+?MsSql?2005?+?Vs?2010

使用步驟:

在使用之前,為大家推薦一款代碼生成器,也是我專為此框架寫的一款代碼生成器,生成iBatis的Map配置文件,這樣一來,用戶不用開任何關于框架的說明文檔,即可使用此框架。代碼生成器(CodeHelper)下載地址與說明:

http://www.cnblogs.com/stone_w/archive/2011/09/26/2192010.html?

第一步:創建數據庫與新建網站項目。

創建數據庫與表的T-sql:

/*

*?iBatisDemo?Sql

*?Stone?(QQ:1370569)

*?Date:2011.09.26

*/

create?database?OrmDB

go

use?OrmDB

go

create?table?People

(

id?int?primary?key?identity,

[name]?varchar(250),

age?int

)

go

打開vs開發工具,新建網站項目。

第二步:為網站添加iBatis框架支持。

為網站添加引用或者直接把下載的iBatis框架中的IBatisNet.Common.dll和IBatisNet.DataMapper.dll復制到Bin目錄下。

第三步:添加iBatis配置文件。

iBatis的配置文件只用三種,也必須要有這三種:

1.providers.config[文件名不能修改]此文件為數據庫開發商提供的驅動配置集合,是固定不變的,無需修改與配置,復制文件到網站的根目錄,代碼如下:

providers.config <?xml version="1.0" encoding="utf-8"?>
<providers
xmlns="http://ibatis.apache.org/providers"
xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance">

<clear/>
<provider
name="sqlServer1.0"
description
="Microsoft SQL Server, provider V1.0.3300.0 in framework .NET V1.0"
enabled
="false"
assemblyName
="System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" connectionClass="System.Data.SqlClient.SqlConnection"
commandClass
="System.Data.SqlClient.SqlCommand"
parameterClass
="System.Data.SqlClient.SqlParameter"
parameterDbTypeClass
="System.Data.SqlDbType"
parameterDbTypeProperty
="SqlDbType"
dataAdapterClass
="System.Data.SqlClient.SqlDataAdapter"
commandBuilderClass
="System.Data.SqlClient.SqlCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
="@"
allowMARS
="false"
/>
<provider
name="sqlServer1.1"
description
="Microsoft SQL Server, provider V1.0.5000.0 in framework .NET V1.1"
enabled
="false"
assemblyName
="System.Data, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
connectionClass
="System.Data.SqlClient.SqlConnection"
commandClass
="System.Data.SqlClient.SqlCommand"
parameterClass
="System.Data.SqlClient.SqlParameter"
parameterDbTypeClass
="System.Data.SqlDbType"
parameterDbTypeProperty
="SqlDbType"
dataAdapterClass
="System.Data.SqlClient.SqlDataAdapter"
commandBuilderClass
="System.Data.SqlClient.SqlCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
="@"
allowMARS
="false"
/>
<provider
name="sqlServer2.0"
enabled
="true"
description
="Microsoft SQL Server, provider V2.0.0.0 in framework .NET V2.0"
assemblyName
="System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
connectionClass
="System.Data.SqlClient.SqlConnection"
commandClass
="System.Data.SqlClient.SqlCommand"
parameterClass
="System.Data.SqlClient.SqlParameter"
parameterDbTypeClass
="System.Data.SqlDbType"
parameterDbTypeProperty
="SqlDbType"
dataAdapterClass
="System.Data.SqlClient.SqlDataAdapter"
commandBuilderClass
=" System.Data.SqlClient.SqlCommandBuilder"
usePositionalParameters
= "false"
useParameterPrefixInSql
= "true"
useParameterPrefixInParameter
= "true"
parameterPrefix
="@"
allowMARS
="false"
/>
<provider
name="sqlServer2005"
enabled
="false"
description
="Microsoft SQL Server, provider V2.0.0.0 in framework .NET V2.0"
assemblyName
="System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
connectionClass
="System.Data.SqlClient.SqlConnection"
commandClass
="System.Data.SqlClient.SqlCommand"
parameterClass
="System.Data.SqlClient.SqlParameter"
parameterDbTypeClass
="System.Data.SqlDbType"
parameterDbTypeProperty
="SqlDbType"
dataAdapterClass
="System.Data.SqlClient.SqlDataAdapter"
commandBuilderClass
=" System.Data.SqlClient.SqlCommandBuilder"
usePositionalParameters
= "false"
useParameterPrefixInSql
= "true"
useParameterPrefixInParameter
= "true"
parameterPrefix
="@"
allowMARS
="true"
/>
<provider name="OleDb1.1"
description
="OleDb, provider V1.0.5000.0 in framework .NET V1.1"
enabled
="false"
assemblyName
="System.Data, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
connectionClass
="System.Data.OleDb.OleDbConnection"
commandClass
="System.Data.OleDb.OleDbCommand"
parameterClass
="System.Data.OleDb.OleDbParameter"
parameterDbTypeClass
="System.Data.OleDb.OleDbType"
parameterDbTypeProperty
="OleDbType"
dataAdapterClass
="System.Data.OleDb.OleDbDataAdapter"
commandBuilderClass
="System.Data.OleDb.OleDbCommandBuilder"
usePositionalParameters
="true"
useParameterPrefixInSql
="false"
useParameterPrefixInParameter
="false"
parameterPrefix
=""
allowMARS
="false"
/>
<provider name="OleDb2.0"
description
="OleDb, provider V2.0.0.0 in framework .NET V2"
enabled
="false"
assemblyName
="System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
connectionClass
="System.Data.OleDb.OleDbConnection"
commandClass
="System.Data.OleDb.OleDbCommand"
parameterClass
="System.Data.OleDb.OleDbParameter"
parameterDbTypeClass
="System.Data.OleDb.OleDbType"
parameterDbTypeProperty
="OleDbType"
dataAdapterClass
="System.Data.OleDb.OleDbDataAdapter"
commandBuilderClass
="System.Data.OleDb.OleDbCommandBuilder"
usePositionalParameters
="true"
useParameterPrefixInSql
="false"
useParameterPrefixInParameter
="false"
parameterPrefix
=""
allowMARS
="false"
/>
<provider
name="Odbc1.1"
description
="Odbc, provider V1.0.5000.0 in framework .NET V1.1"
enabled
="false"
assemblyName
="System.Data, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
connectionClass
="System.Data.Odbc.OdbcConnection"
commandClass
="System.Data.Odbc.OdbcCommand"
parameterClass
="System.Data.Odbc.OdbcParameter"
parameterDbTypeClass
="System.Data.Odbc.OdbcType"
parameterDbTypeProperty
="OdbcType"
dataAdapterClass
="System.Data.Odbc.OdbcDataAdapter"
commandBuilderClass
="System.Data.Odbc.OdbcCommandBuilder"
usePositionalParameters
="true"
useParameterPrefixInSql
="false"
useParameterPrefixInParameter
="false"
parameterPrefix
="@"
allowMARS
="false"
/>
<provider
name="Odbc2.0"
description
="Odbc, provider V2.0.0.0 in framework .NET V2"
enabled
="false"
assemblyName
="System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
connectionClass
="System.Data.Odbc.OdbcConnection"
commandClass
="System.Data.Odbc.OdbcCommand"
parameterClass
="System.Data.Odbc.OdbcParameter"
parameterDbTypeClass
="System.Data.Odbc.OdbcType"
parameterDbTypeProperty
="OdbcType"
dataAdapterClass
="System.Data.Odbc.OdbcDataAdapter"
commandBuilderClass
="System.Data.Odbc.OdbcCommandBuilder"
usePositionalParameters
="true"
useParameterPrefixInSql
="false"
useParameterPrefixInParameter
="false"
parameterPrefix
="@"
allowMARS
="false"
/>
<provider
name="oracle9.2"
description
="Oracle, Oracle provider V9.2.0.401"
enabled
="false"
assemblyName
="Oracle.DataAccess, Version=9.2.0.401, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionClass="Oracle.DataAccess.Client.OracleConnection"
commandClass
="Oracle.DataAccess.Client.OracleCommand"
parameterClass
="Oracle.DataAccess.Client.OracleParameter"
parameterDbTypeClass
="Oracle.DataAccess.Client.OracleDbType"
parameterDbTypeProperty
="OracleDbType"
dataAdapterClass
="Oracle.DataAccess.Client.OracleDataAdapter"
commandBuilderClass
="Oracle.DataAccess.Client.OracleCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="false"
parameterPrefix
=":"
useDeriveParameters
="false"
allowMARS
="false"
/>
<provider
name="oracle10.1"
description
="Oracle, oracle provider V10.1.0.301"
enabled
="false"
assemblyName
="Oracle.DataAccess, Version=10.1.0.301, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionClass="Oracle.DataAccess.Client.OracleConnection"
commandClass
="Oracle.DataAccess.Client.OracleCommand"
parameterClass
="Oracle.DataAccess.Client.OracleParameter"
parameterDbTypeClass
="Oracle.DataAccess.Client.OracleDbType"
parameterDbTypeProperty
="OracleDbType"
dataAdapterClass
="Oracle.DataAccess.Client.OracleDataAdapter"
commandBuilderClass
="Oracle.DataAccess.Client.OracleCommandBuilder"
usePositionalParameters
="true"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
=":"
useDeriveParameters
="false"
allowMARS
="false"
/>
<provider
name="oracleClient1.0"
description
="Oracle, Microsoft provider V1.0.5000.0"
enabled
="false"
assemblyName
="System.Data.OracleClient, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" connectionClass="System.Data.OracleClient.OracleConnection"
commandClass
="System.Data.OracleClient.OracleCommand"
parameterClass
="System.Data.OracleClient.OracleParameter"
parameterDbTypeClass
="System.Data.OracleClient.OracleType"
parameterDbTypeProperty
="OracleType"
dataAdapterClass
="System.Data.OracleClient.OracleDataAdapter"
commandBuilderClass
="System.Data.OracleClient.OracleCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="false"
parameterPrefix
=":"
allowMARS
="false"
/>
<provider
name="ByteFx"
description
="MySQL, ByteFx provider V0.7.6.15073"
enabled
="false"
assemblyName
="ByteFX.MySqlClient, Version=0.7.6.15073, Culture=neutral, PublicKeyToken=f2fef6fed1732fc1" connectionClass="ByteFX.Data.MySqlClient.MySqlConnection"
commandClass
="ByteFX.Data.MySqlClient.MySqlCommand"
parameterClass
="ByteFX.Data.MySqlClient.MySqlParameter"
parameterDbTypeClass
="ByteFX.Data.MySqlClient.MySqlDbType"
parameterDbTypeProperty
="MySqlDbType"
dataAdapterClass
="ByteFX.Data.MySqlClient.MySqlDataAdapter"
commandBuilderClass
="ByteFX.Data.MySqlClient.MySqlCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
="@"
allowMARS
="false"
/>
<provider
name="MySql"
description
="MySQL, MySQL provider 1.0.7.30072"
enabled
="false"
assemblyName
="MySql.Data, Version=1.0.7.30072, Culture=neutral, PublicKeyToken=c5687fc88969c44d" connectionClass="MySql.Data.MySqlClient.MySqlConnection"
commandClass
="MySql.Data.MySqlClient.MySqlCommand"
parameterClass
="MySql.Data.MySqlClient.MySqlParameter"
parameterDbTypeClass
="MySql.Data.MySqlClient.MySqlDbType"
parameterDbTypeProperty
="MySqlDbType"
dataAdapterClass
="MySql.Data.MySqlClient.MySqlDataAdapter"
commandBuilderClass
="MySql.Data.MySqlClient.MySqlCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
="?"
allowMARS
="false"
/>
<provider name="SQLite3 Finisar"
description
="SQLite, SQLite.NET provider V0.21.1869.3794"
enabled
="false"
assemblyName
="SQLite.NET, Version=0.21.1869.3794, Culture=neutral, PublicKeyToken=c273bd375e695f9c"
connectionClass
="Finisar.SQLite.SQLiteConnection"
commandClass
="Finisar.SQLite.SQLiteCommand"
parameterClass
="Finisar.SQLite.SQLiteParameter"
parameterDbTypeClass
="System.Data.DbType, System.Data"
parameterDbTypeProperty
="DbType"
dataAdapterClass
="Finisar.SQLite.SQLiteDataAdapter"
commandBuilderClass
="Finisar.SQLite.SQLiteCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
="@"
setDbParameterPrecision
="false"
setDbParameterScale
="false"
allowMARS
="false"
/>
<provider name="SQLite3"
description
="SQLite, SQLite.NET provider V1.0.43.0"
enabled
="false"
assemblyName
="System.Data.SQLite, Version=1.0.43.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139"
connectionClass
="System.Data.SQLite.SQLiteConnection"
commandClass
="System.Data.SQLite.SQLiteCommand"
parameterClass
="System.Data.SQLite.SQLiteParameter"
parameterDbTypeClass
="System.Data.SQLite.SQLiteType"
parameterDbTypeProperty
="DbType"
dataAdapterClass
="System.Data.SQLite.SQLiteDataAdapter"
commandBuilderClass
="System.Data.SQLite.SQLiteCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
="@"
setDbParameterPrecision
="false"
setDbParameterScale
="false"
allowMARS
="false"
/>
<provider
name="Firebird1.7"
description
="Firebird, Firebird SQL .NET provider V1.7.0.33200"
enabled
="false"
assemblyName
="FirebirdSql.Data.Firebird, Version=1.7.0.33200, Culture=neutral, PublicKeyToken=fa843d180294369d" connectionClass="FirebirdSql.Data.Firebird.FbConnection"
commandClass
="FirebirdSql.Data.Firebird.FbCommand"
parameterClass
="FirebirdSql.Data.Firebird.FbParameter"
parameterDbTypeClass
="FirebirdSql.Data.Firebird.FbDbType"
parameterDbTypeProperty
="FbDbType"
dataAdapterClass
="FirebirdSql.Data.Firebird.FbDataAdapter"
commandBuilderClass
="FirebirdSql.Data.Firebird.FbCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
="@"
allowMARS
="false"
/>
<provider
name="PostgreSql0.99.1.0"
description
="PostgreSql, Npgsql provider V0.99.1.0"
enabled
="false"
assemblyName
="Npgsql, Version=0.99.1.0, Culture=neutral, PublicKeyToken=5d8b90d52f46fda7"
connectionClass
="Npgsql.NpgsqlConnection"
commandClass
="Npgsql.NpgsqlCommand"
parameterClass
="Npgsql.NpgsqlParameter"
parameterDbTypeClass
="NpgsqlTypes.NpgsqlDbType"
parameterDbTypeProperty
="NpgsqlDbType"
dataAdapterClass
="Npgsql.NpgsqlDataAdapter"
commandBuilderClass
="Npgsql.NpgsqlCommandBuilder"
usePositionalParameters
="false"
useParameterPrefixInSql
="true"
useParameterPrefixInParameter
="true"
parameterPrefix
=":"
allowMARS
="true"
/>
<provider
name="iDb2.10"
description
="IBM DB2 Provider, V 10.0"
enabled
="false"
assemblyName
="IBM.Data.DB2.iSeries, Version=10.0.0.0,Culture=neutral, PublicKeyToken=9cdb2ebfb1f93a26, Custom=null" connectionClass="IBM.Data.DB2.iSeries.iDB2Connection"
commandClass
="IBM.Data.DB2.iSeries.iDB2Command"
parameterClass
="IBM.Data.DB2.iSeries.iDB2Parameter"
parameterDbTypeClass
="IBM.Data.DB2.iSeries.iDB2DbType"
parameterDbTypeProperty
="iDB2DbType"
dataAdapterClass
="IBM.Data.DB2.iSeries.iDB2DataAdapter"
commandBuilderClass
="IBM.Data.DB2.iSeries.iDB2CommandBuilder"
usePositionalParameters
="true"
useParameterPrefixInSql
="false"
useParameterPrefixInParameter
="false"
parameterPrefix
=""
allowMARS
="false"
/>
<provider
name="Informix"
description
="Informix NET Provider, 2.81.0.0"
enabled
="false"
assemblyName
="IBM.Data.Informix, Version=2.81.0.0, Culture=neutral, PublicKeyToken=7c307b91aa13d208"
connectionClass
="IBM.Data.Informix.IfxConnection"
commandClass
="IBM.Data.Informix.IfxCommand"
parameterClass
="IBM.Data.Informix.IfxParameter"
parameterDbTypeClass
="IBM.Data.Informix.IfxType"
parameterDbTypeProperty
="IfxType"
dataAdapterClass
="IBM.Data.Informix.IfxDataAdapter"
commandBuilderClass
="IBM.Data.Informix.IfxCommandBuilder"
usePositionalParameters
= "true"
useParameterPrefixInSql
= "false"
useParameterPrefixInParameter
= "false"
useDeriveParameters
="false"
allowMARS
="false"
/>
</providers>


2.SQLMap.config[文件名不可修改],配置連接數據庫字符串與每個實體類(表)的映射文件配置,復制文件到網站的根目錄,代碼如下:

<?xml?version="1.0"?encoding="utf-8"?>

<sqlMapConfig

??xmlns="http://ibatis.apache.org/dataMapper"

??xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

????<settings>

????????<!--/是否使用Satement命名空間,這里的命名空間指的是映射文件中sqlMap節點的namespace屬性,默認是false-->

????????<setting?useStatementNamespaces="false"/>

????????<!--是否啟用DataMapper的緩存機制,針對全部的SqlMap,默認是true-->

????????<setting?cacheModelsEnabled="true"/>

????????<!--是否啟用SqlMapConfig.xsd?schema驗證映射文件,默認是false-->

????????<setting?validateSqlMap="false"/>

????</settings>

????<!--配置數據驅動提供類配置文件的路徑和文件名-->

????<providers?resource="providers.config"/>

????<!--如果在providers.config文件中指定了默認的數據庫驅動,那么provider節點就不需要設置了,它的作用是在換數據庫驅動時不需要修改providers.config文件。datasource節點用于指定ADO.NET?Connection?String.-->

????<database>

????????<provider?name="sqlServer2.0"/>

????????<dataSource?name="mydb"?connectionString="data?source=127.0.0.1;database=MyBatisDB;user?id=sa;password=sa;"/>

????</database>

????<!--指定映射的文件的位置-->

????<sqlMaps>

????????<sqlMap?resource="Maps/PeopleMap.xml"/>

????</sqlMaps>

</sqlMapConfig>

3.每個實體類(表)都有一個單獨的配置文件類,類型為xml。代碼生成器也是生成這個類的,這樣一來,用戶就可以幾秒鐘創建開發一個iBatis項目了,實體類的配置文件格式如下,在網站的根目錄創建一個Map的文件夾,新建xxxMap.xml格式的配置類,比如:PeopleMap.xml文件,示例代碼如下:

<?xml?version="1.0"?encoding="utf-8"??>

<!--namespace必須用否者就報錯(讀取配置文件報:未將對象引用設置到對象的實例)-->

<sqlMap?namespace=""?xmlns="http://ibatis.apache.org/mapping"?xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

????<statements>

????????<select?id="GetPeopleById"?parameterClass="string"?resultClass="HashTable">

????????????SELECT?*?FROM?People?WHERE?Id=#Id#

????????</select>

????????<insert?id="Add"?parameterClass="hashtable">

????????????INSERT??dbo.People?(name?,age)

????????????VALUES??(#Name#?,?#Age#)

????????</insert>

????????<delete?id="Delete"?parameterClass="int"?restultClass="int">

????????????DELETE?FROM?dbo.People?WHERE?Id=#Id#

????????</delete>

????????<update?id="Update"?parameterClass="hashtable"?restltClass="int">

????????????UPDATE?People?SET?name=#Name#?WHERE?Id=#Id#

????????</update>

????????<select?id="GetAll"?resultClass="HashTable">

????????????SELECT?*?FROM?People

????????</select>

????</statements>

</sqlMap>

這三類配置文件必須都要有,與其他orm框架不同的是,web.config什么也不用配置,及時練數據庫連接字符串也不是在它的文件中配置的,也就是web.config是沒有被用到的。

第四步:iBatis框架語法與使用。

使用之前先來加入一個DB輔助類IBatisHepler.cs,代碼如下:

IBatisHepler.cs using System;
using System.Collections.Generic;
using System.Text;
using IBatisNet.DataMapper.Configuration.Statements;
using IBatisNet.DataMapper;
using IBatisNet.DataMapper.MappedStatements;
using IBatisNet.Common;
using IBatisNet.DataMapper.Scope;
using System.Data;
using IBatisNet.DataMapper.Configuration;
using System.Collections;


/// <summary>
/// IBatis 使用工具類
/// </summary>
public class IBatisHepler
{
private static ISqlMapper mapper = null;
static IBatisHepler()
{
DomSqlMapBuilder builder = new DomSqlMapBuilder();//其作用是根據配置文件創建SqlMap實例。
mapper = builder.Configure("SqlMap.config") as SqlMapper;//SqlMapper是iBatisNet的核心組件,提供數據庫操作的基礎平臺。SqlMapper可通過DomSqlMapBuilder創建。
}
/// <summary>
/// 執行添加操作
/// </summary>
/// <param name="tag">語句ID</param>
/// <param name="paramObject">語句所需要的參數</param>
/// <returns>添加的主鍵</returns>
public static object ExcuteInsert(string tag, Hashtable paramObject)
{
return mapper.Insert(tag, paramObject);
}
/// <summary>
/// 執行刪除操作
/// </summary>
/// <param name="tag">語句ID</param>
/// <param name="paramObject">語句所需要的參數</param>
/// <returns>影響行數</returns>
public static int ExcuteDelete(string tag, object paramObject)
{
return mapper.Delete(tag, paramObject);
}
/// <summary>
/// 執行修改操作
/// </summary>
/// <param name="tag">語句ID</param>
/// <param name="paramObject">語句所需要的參數</param>
/// <returns>影響行數</returns>
public static int ExcuteUpdate(string tag, Hashtable paramObject)
{
return mapper.Update(tag, paramObject);
}
/// <summary>
/// 查詢單個實體對象
/// </summary>
/// <param name="tag">語句ID</param>
/// <param name="paramObject">語句所需要的參數</param>
/// <returns>得到的Object</returns>
public static object ExcuteSelectObj(string tag, object paramObject)
{
object obj = mapper.QueryForObject(tag, paramObject);
return obj;
}
/// <summary>
/// 分頁查詢
/// </summary>
/// <param name="tag">語句ID</param>
/// <param name="paramObject">語句所需要的參數</param>
/// <param name="pageIndex">頁索引</param>
/// <param name="pageSize">每頁顯示的記錄數</param>
/// <returns>得到的List集合</returns>
public static IList ExcuteSelect(string tag, object paramObject, int pageIndex, int pageSize)
{
return mapper.QueryForList(tag, paramObject, pageIndex, pageSize);
}
/// <summary>
/// 通用的以DataTable的方式得到Select的結果(xml文件中參數要使用$標記的占位參數)
/// </summary>
/// <param name="tag">語句ID</param>
/// <param name="paramObject">語句所需要的參數</param>
/// <returns>得到的DataTable</returns>
public static DataTable ExcuteSelect(string tag, object paramObject)
{
DataSet ds = new DataSet();
bool isSessionLocal = false;
ISqlMapSession session = mapper.LocalSession;
if (session == null)
{
session = mapper.CreateSqlMapSession();
session.OpenConnection();
isSessionLocal = true;
}
try
{
IDbCommand cmd = session.CreateCommand(CommandType.Text);
cmd.Connection = session.Connection;
cmd.CommandText = GetSql(tag, paramObject);
IDbDataAdapter adapter = session.CreateDataAdapter(cmd);
adapter.Fill(ds);
}
finally
{
if (isSessionLocal)
{
session.CloseConnection();
}
}
return ds.Tables[0];
}
/// <summary>
/// 得到參數化后的SQL
/// </summary>
/// <param name="tag">語句ID</param>
/// <param name="paramObject">語句所需要的參數</param>
/// <returns>sql語句</returns>
protected static string GetSql(string tag, object paramObject)
{
IStatement statement = mapper.GetMappedStatement(tag).Statement;
IMappedStatement mapStatement = mapper.GetMappedStatement(tag);
ISqlMapSession session = mapper.CreateSqlMapSession();
RequestScope request = statement.Sql.GetRequestScope(mapStatement, paramObject, session);
return request.PreparedStatement.PreparedSql;
}
/// <summary>
/// 用于分頁控件使用
/// </summary>
/// <param name="tag">語句ID</param>
/// <param name="paramObject">語句所需要的參數</param>
/// <param name="PageSize">每頁顯示數目</param>
/// <param name="curPage">當前頁</param>
/// <param name="recCount">記錄總數</param>
/// <returns>得到的DataTable</returns>
public static DataTable ExcuteSelect(string tag, object paramObject, int PageSize, int curPage, out int recCount)
{
IDataReader dr = null;
bool isSessionLocal = false;
string sql = GetSql(tag, paramObject);
string strCount = "select count(*) " + sql.Substring(sql.ToLower().IndexOf("from"));
IDalSession session = mapper.LocalSession;
DataTable dt = new DataTable();
if (session == null)
{
session = mapper.CreateSqlMapSession();
session.OpenConnection();
isSessionLocal = true;
}
try
{
IDbCommand cmdCount = session.CreateCommand(CommandType.Text);
cmdCount.Connection = session.Connection;
cmdCount.CommandText = strCount;
object count = cmdCount.ExecuteScalar();
recCount = Convert.ToInt32(count);
IDbCommand cmd = session.CreateCommand(CommandType.Text);
cmd.Connection = session.Connection;
cmd.CommandText = sql;
dr = cmd.ExecuteReader();
dt = Paging(dr, PageSize, curPage);
}
finally
{
if (isSessionLocal)
{
session.CloseConnection();
}
}
return dt;
}

/**/
/// <summary>
/// 取回合適數量的數據
/// </summary>
/// <param name="dataReader"></param>
/// <param name="PageSize"></param>
/// <param name="curPage"></param>
/// <returns></returns>
protected static DataTable Paging(IDataReader dataReader, int PageSize, int curPage)
{
DataTable dt;
dt = new DataTable();
int colCount = dataReader.FieldCount;
for (int i = 0; i < colCount; i++)
{
dt.Columns.Add(new DataColumn(dataReader.GetName(i), dataReader.GetFieldType(i)));
}
// 讀取數據。將DataReader中的數據讀取到DataTable中
object[] vald = new object[colCount];
int iCount = 0; // 臨時記錄變量
while (dataReader.Read())
{
// 當前記錄在當前頁記錄范圍內
if (iCount >= PageSize * (curPage - 1) && iCount < PageSize * curPage)
{
for (int i = 0; i < colCount; i++)
vald[i] = dataReader.GetValue(i);
dt.Rows.Add(vald);
}
else if (iCount > PageSize * curPage)
{
break;
}
iCount++; // 臨時記錄變量遞增
}
if (!dataReader.IsClosed)
{
dataReader.Close();
dataReader.Dispose();
}
return dt;
}
}


使用語法如下:

//?添加引用

using?System.Collections;

using?IBatisNet.DataMapper;

using?IBatisNet.DataMapper.Configuration;

//?1.添加

Hashtable?ht_add?=?new?Hashtable();

ht_add["Name"]?=?"IBatis";??//?[注意]大小寫要和xxxMap.xml里保持一致

ht_add["Age"]?=?2001;

IBatisHepler.ExcuteInsert("Add",?ht_add);

//?2.修改

Hashtable?ht_up?=?new?Hashtable();

ht_up["Id"]?=?"1";

ht_up["Name"]?=?"IBatis";

ht_up["Age"]?=?2001;

IBatisHepler.ExcuteUpdate("Update",?ht_up);

//?3.刪除

IBatisHepler.ExcuteDelete("Delete",?14);

//?4.查詢

Repeater1.DataSource?=?IBatisHepler.ExcuteSelectObj("GetPeopleById",?"1");

Repeater1.DataBind();


我對此框架的評價:配置文件有點多,用戶需要去寫東西比較多,調用查詢不是很好用,尤其是條件查詢很不方便。

代碼下載:【①.本Demo下載】


Orm框架相關文章鏈接:

1.NHibernate使用之詳細圖解

2.iBatis for net 框架使用

3.iBatis for Net 代碼生成器(CodeHelper)附下載地址

4.NBear簡介與使用圖解?

5.SubSonic框架使用圖解

6.GentleNet使用之詳細圖解

總結

以上是生活随笔為你收集整理的iBatis for net 框架使用的全部內容,希望文章能夠幫你解決所遇到的問題。

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

开心激情婷婷 | 中文字幕黄色网址 | 999国内精品永久免费视频 | 最近中文字幕在线中文高清版 | 国内丰满少妇猛烈精品播 | 黄色三级在线 | 福利二区视频 | 精品久久久久一区二区国产 | 久久你懂得 | 91丨九色丨国产女 | av在线免费播放 | av在线8 | 偷拍精偷拍精品欧洲亚洲网站 | 午夜国产福利在线 | 91色一区二区三区 | 久久电影网站中文字幕 | av免费在线观看网站 | 在线观看免费成人 | 在线观看国产中文字幕 | 99在线热播精品免费 | 激情深爱五月 | 国产日产高清dvd碟片 | 在线看片视频 | 99草在线视频 | 韩国一区视频 | 99久久免费看 | 波多野结衣日韩 | 欧美日韩久久久 | 国产精品爽爽久久久久久蜜臀 | a在线播放 | 免费av片在线 | 色多多污污 | 天堂中文在线视频 | 91免费看黄色| 免费a现在观看 | 色综合久久五月 | 天天av天天 | 激情电影影院 | 国产在线观看你懂的 | 成年人黄色大片在线 | 香蕉手机在线 | 天天干,夜夜操 | 国产精品99久久免费黑人 | 91人人澡人人爽人人精品 | 99精品视频在线看 | 国产性天天综合网 | 99久热在线精品视频成人一区 | 国产精品白浆视频 | 午夜精品福利一区二区 | 99久久精品国产毛片 | 国产一区福利在线 | 日韩av有码在线 | 免费欧美 | 麻豆影视在线免费观看 | 日韩av三区 | 欧美日韩成人一区 | 99精品国产福利在线观看免费 | 亚洲激情综合网 | 国产一区 在线播放 | 国产亚州av | 国产第一福利 | 日本公妇在线观看 | 正在播放亚洲精品 | 欧美一区二区伦理片 | 麻豆系列在线观看 | 欧美激情在线网站 | 国产成人精品免费在线观看 | 久久国产露脸精品国产 | 日本久久电影网 | 久久亚洲婷婷 | 国产亚洲人 | 怡红院av久久久久久久 | 欧美一二三在线 | 黄色av电影一级片 | 天天操夜夜爱 | 日韩免费一级电影 | 六月色婷婷 | 9797在线看片亚洲精品 | 午夜精品一区二区三区在线观看 | 操操操综合 | 亚洲精品美女免费 | 天天综合日日夜夜 | 色无五月 | 国产精品福利久久久 | 国产精品久久久久久久电影 | 久产久精国产品 | 美女很黄免费网站 | 国产主播99| 国产综合91 | 亚洲欧美日韩精品一区二区 | 99久久精品午夜一区二区小说 | 中文字幕免费高清在线观看 | 日韩精品一区二区三区免费观看视频 | 中文字幕久久精品亚洲乱码 | 欧美一区二区日韩一区二区 | 综合色婷婷| 蜜臀av性久久久久蜜臀aⅴ四虎 | av片子在线观看 | 午夜精品一区二区三区在线视频 | 日韩在线电影一区 | 欧美极品少妇xbxb性爽爽视频 | 天天在线免费视频 | 色婷婷精品大在线视频 | 久久99日韩 | 综合色久 | 五月婷婷.com | 观看免费av| 久久这里只有精品1 | 精品1区二区 | 四虎影视久久久 | 亚洲免费精品一区二区 | 午夜久久精品 | 亚州天堂 | 中文字幕av在线不卡 | 99久久精品免费看国产 | 成人黄色电影在线 | 在线视频a | 国产黄色网 | a天堂最新版中文在线地址 久久99久久精品国产 | 日韩国产精品久久久久久亚洲 | 在线观看视频中文字幕 | 免费a级观看 | 亚洲欧美日韩不卡 | 亚洲精品理论片 | 2023国产精品自产拍在线观看 | 国产伦精品一区二区三区四区视频 | 欧美激情在线看 | 国产精品国产三级国产不产一地 | 午夜电影中文字幕 | 国产黄在线播放 | 日日操日日 | 久久综合国产伦精品免费 | 欧美日韩精品在线免费观看 | 最新中文字幕 | 亚洲视频1区2区 | 久久99这里只有精品 | 久久久久看片 | 81国产精品久久久久久久久久 | 超碰在线亚洲 | 亚洲精品视频在线观看免费视频 | 九九色综合 | 国产资源中文字幕 | 欧美视频在线观看免费网址 | 99精品国产免费久久久久久下载 | 国产精品一区二区62 | 天天插狠狠干 | 国产性天天综合网 | 国精产品999国精产 久久久久 | 久久久99精品免费观看乱色 | 狠狠狠色丁香婷婷综合久久88 | 91在线最新| 狠狠色丁香婷婷综合久小说久 | 国产精品区二区三区日本 | 欧美高清视频不卡网 | 亚洲国产成人久久 | 五月天丁香视频 | 国产福利精品视频 | 欧美日韩视频在线观看一区二区 | 日韩在线观看小视频 | 国产精品成人一区二区三区 | 成人在线观看免费 | ,午夜性刺激免费看视频 | 成人黄色毛片 | 在线免费观看麻豆视频 | 国产一区二区精品久久 | 欧美 日韩 成人 | 午夜精品久久久久久久99热影院 | 国产视频精品免费 | 91成人在线免费观看 | 国产在线精品一区二区不卡了 | www.黄色片网站 | 中文字幕免费国产精品 | 狠狠躁天天躁综合网 | 免费在线视频一区二区 | 久久亚洲欧美日韩精品专区 | 亚洲精品裸体 | 中文字幕日韩一区二区三区不卡 | av一级片在线观看 | 在线播放 日韩专区 | 日韩欧美高清在线观看 | 日韩丝袜视频 | 亚洲国产日韩在线 | 在线视频观看亚洲 | 丁香六月久久综合狠狠色 | 国产精品美女视频 | 久久成人一区二区 | 91精品视频在线播放 | 久久久免费电影 | 最近免费中文字幕 | 91九色老| 黄色毛片视频免费观看中文 | 在线观看久久久久久 | 天堂黄色片| 国产精品黑丝在线观看 | 亚洲在线成人精品 | 成年人黄色免费看 | 亚洲欧美日韩国产精品一区午夜 | 亚洲视频免费在线看 | 成人午夜在线电影 | 成年人看片网站 | 天天干夜夜夜操天 | 国产精品va在线播放 | 色婷婷综合久久久久 | 成 人 黄 色视频免费播放 | 免费日韩 | 人人草人 | 日韩精品欧美精品 | 伊人久久精品久久亚洲一区 | 天天操操操操操 | 日韩高清毛片 | 三级视频日韩 | 国产在线一区观看 | 日本精品二区 | 干狠狠| 中文字幕第一页在线播放 | 久操97 | 伊人狠狠干 | www免费网站在线观看 | 91麻豆精品 | 日本 在线 视频 中文 有码 | 91精品国自产在线观看欧美 | 日本一区二区三区视频在线播放 | 久久国产精品99久久久久久丝袜 | 在线中文字幕av观看 | 中文字幕免费不卡视频 | 亚洲另类视频在线 | 欧美日本不卡视频 | 中文乱幕日产无线码1区 | 香蕉视频在线看 | 欧美美女激情18p | 天天搞天天干 | 国产日韩精品一区二区 | 韩国av电影在线观看 | 天天操夜夜操天天射 | 免费观看www7722午夜电影 | 欧日韩在线 | 精品视频成人 | 丁香六月婷婷开心 | 麻豆久久一区二区 | 久草久草久草久草 | 欧美激情精品久久久久久免费印度 | 精品久久久久久亚洲综合网 | 一级片免费在线 | 一性一交视频 | 亚洲国内精品视频 | 婷婷六月中文字幕 | 亚洲婷婷免费 | 亚洲成人高清在线 | 午夜精品久久久久久久99无限制 | 成年人在线免费看视频 | 日本不卡一区二区三区在线观看 | 91av在线视频免费观看 | 欧美久久久久久久久久久久久 | 国产中文字幕精品 | 久久精品亚洲一区二区三区观看模式 | 91亚洲精品久久久蜜桃借种 | 婷婷久久综合网 | 玖玖视频免费在线 | 国产不卡免费av | 天天天天色射综合 | 在线观看久久久久久 | 久久r精品| 欧美激情第28页 | 久久免费国产精品 | 一区二区三区免费在线观看视频 | 97色噜噜 | 精品字幕 | 91中文在线视频 | 国产精品一区二区久久精品爱微奶 | 国内精品久久久久国产 | 国产精品密入口果冻 | 国产精品原创 | 欧美最猛性xxxxx(亚洲精品) | 亚洲精品午夜一区人人爽 | 国产成人精品亚洲 | 91网站在线视频 | 中文字幕永久免费 | 色香蕉在线 | 97色在线视频 | 国产精品一区二区三区免费看 | 在线看小早川怜子av | 亚洲免费永久精品国产 | 日韩一区视频在线 | 国产91精品看黄网站在线观看动漫 | 国产色a在线观看 | 国产日产亚洲精华av | 在线观看国产 | 久草五月| 午夜精品一区二区三区在线视频 | 国产中文字幕在线观看 | 日韩羞羞 | 黄色大片日本免费大片 | se视频网址 | av日韩av | 337p欧美| 丁香六月色 | 天天综合导航 | 在线成人中文字幕 | 91麻豆精品国产91久久久无需广告 | 99r在线 | 免费成人在线视频网站 | 国产亚洲精品久久久久久网站 | 成人一级在线 | 黄色av一区二区 | 婷婷丁香在线 | 国产免费成人 | 久久久一本精品99久久精品66 | 99久热在线精品视频观看 | 欧美激情综合五月色丁香小说 | 天天干com| 视频在线播放国产 | 婷婷网站天天婷婷网站 | 亚洲国产精品视频 | 五月天av在线 | 天堂视频一区 | 国产在线观看国语版免费 | 国产精品中文久久久久久久 | 色综合天天爱 | 国产精品久久久久久久久久久久午夜片 | 久久综合久久伊人 | 国产成人精品一区二区三区免费 | 亚洲播放一区 | 亚洲婷婷丁香 | 日韩欧美在线观看一区 | 成 人 黄 色 视频免费播放 | 婷婷伊人综合亚洲综合网 | 2022中文字幕在线观看 | 欧美在线91 | 精品国产一区二区三区四区vr | 国产成人精品一区二区在线 | 国产不卡精品 | 黄色三级在线看 | 精品女同一区二区三区在线观看 | 成人a在线观看高清电影 | 国产精品日韩在线 | 97成人精品区在线播放 | 成人av影视观看 | 五月天六月婷 | 国内精品在线观看视频 | 97在线观看视频免费 | 五月婷婷综合激情网 | 国产精品一区二区吃奶在线观看 | 久草爱| 久久不卡免费视频 | 在线看国产日韩 | 久久视频网址 | 久草在线免费色站 | 四虎小视频 | 国际精品久久 | 在线观看 国产 | 亚洲蜜桃在线 | 欧美精品久久久久久久免费 | 成人黄性视频 | 丁香影院在线 | 91专区在线观看 | 成人性生交大片免费观看网站 | 国产精品av一区二区 | 九九亚洲精品 | 亚洲午夜久久久久久久久 | 在线观看国产v片 | 国产精品18videosex性欧美 | 日韩黄色免费在线观看 | 天天操夜夜操国产精品 | 久久精品视频网 | 一个色综合网站 | av 一区 二区 久久 | 亚洲专区欧美 | 99视频在线免费观看 | 99麻豆久久久国产精品免费 | 亚洲国产成人av网 | 精品国产美女在线 | 黄色一级性片 | 国产亚洲久一区二区 | 91精品视频在线免费观看 | 亚洲国内精品在线 | 久久精品一区二区 | 激情欧美丁香 | 欧美亚洲一区二区在线 | 欧美专区亚洲专区 | 美州a亚洲一视本频v色道 | 午夜久久影视 | 亚洲mv大片欧洲mv大片免费 | 色综合人人| 日韩欧美黄色网址 | 亚洲色图 校园春色 | 日本性生活一级片 | 日韩中文久久 | 在线国产专区 | 国产色中涩 | 中文字幕在线观看一区二区 | 欧美伦理一区二区三区 | 97国产精品久久 | 免费在线国产黄色 | 在线免费视频你懂的 | 天天射天天 | 日韩精品在线免费播放 | 爱色av.com| 五月婷丁香 | 日韩av电影手机在线观看 | 特黄一级毛片 | 在线观看韩日电影免费 | 97天天综合网 | 九七在线视频 | 婷婷亚洲综合五月天小说 | 黄av免费在线观看 | 成人国产综合 | 天堂在线一区二区三区 | 久久精品视频国产 | 国产99中文字幕 | 成人黄色大片 | 久久久不卡影院 | 久草成人在线 | 一区二区三区视频在线 | 九九精品毛片 | 欧美a√在线 | 亚洲精品三级 | 久久视频一区 | 欧美 日韩 视频 | 欧美日韩在线视频一区二区 | 日韩羞羞 | 亚洲人xxx | 99在线视频网站 | 久久综合亚洲鲁鲁五月久久 | 国产又粗又硬又长又爽的视频 | h网站免费在线观看 | 久久久麻豆精品一区二区 | 欧美成人999 | 国产精品 日韩精品 | 欧美资源 | 在线 高清 中文字幕 | 麻豆91精品视频 | 91欧美日韩国产 | 97偷拍视频 | 麻豆免费精品视频 | 免费观看9x视频网站在线观看 | 欧美亚洲专区 | 91精品播放| 欧美精品一区在线发布 | 97色视频在线 | 日韩欧美精品一区二区 | 国产亚洲欧美精品久久久久久 | 五月丁色 | 性色av免费在线观看 | 精品成人免费 | 国产精品 亚洲精品 | 午夜色婷婷 | 国产精品福利在线观看 | 成人一级片免费看 | 99久久国产免费,99久久国产免费大片 | 女人18毛片90分钟 | 日韩精品一区二区免费 | 婷婷精品进入 | 国产a高清 | 91大神一区二区三区 | www.在线观看视频 | 日本精品视频免费 | 91精品一区二区三区蜜桃 | 91av九色 | 国产明星视频三级a三级点| 日韩资源在线播放 | 久草久热 | 天天操天天射天天操 | 中文字幕在线播放第一页 | 国产一区二区免费在线观看 | 成人app在线播放 | 免费a级黄色毛片 | 国产精品 视频 | 操操操人人| 激情网站免费观看 | 免费黄色av | 免费激情在线电影 | 91在线精品视频 | 成人cosplay福利网站 | 中午字幕在线观看 | 国产黄色在线看 | 国产精品第一视频 | 91免费版在线观看 | 国产一级黄色片免费看 | 成人国产一区二区 | 黄污网站在线观看 | 亚洲国产欧美一区二区三区丁香婷 | 国产麻豆视频在线观看 | 国产精品麻豆视频 | 久久超碰99| 国产精品12 | 91精品国产91久久久久久三级 | 久久免费精品视频 | 日本中文字幕视频 | 国产一区二区播放 | 91激情小视频 | 亚洲91精品在线观看 | 亚洲a免费 | 免费国产在线观看 | 国产精品乱码久久久久久1区2区 | 成人中文字幕+乱码+中文字幕 | 91丨porny丨九色 | 91精品国产麻豆国产自产影视 | 欧美va天堂在线电影 | 久久艹精品 | av片在线观看免费 | 久99久精品视频免费观看 | 国产在线不卡 | 日韩免费一区二区在线观看 | 亚洲国产片色 | 五月婷婷深开心 | 久草在线视频首页 | 国产系列 在线观看 | 激情欧美国产 | 蜜臀av性久久久久av蜜臀三区 | 日韩精品一区电影 | 99在线观看视频 | 亚洲精品久久久蜜桃直播 | 国产黄在线免费观看 | 欧美精品一级视频 | 欧美另类z0zx | 天天操天天操天天 | 国产精品系列在线观看 | 日韩久久精品一区二区 | 尤物一区二区三区 | 亚洲第一av在线播放 | 亚洲精品福利在线观看 | 97精品免费视频 | 激情在线免费视频 | 国产综合精品一区二区三区 | 六月丁香婷婷久久 | 欧美成人精品三级在线观看播放 | 91毛片在线 | 国产999精品久久久久久 | 国产成人一区二区三区电影 | 中文字幕首页 | 国产精品久久久久久999 | 日韩一区二区三免费高清在线观看 | 国产成人高清av | 在线免费观看视频a | 中文字幕av在线电影 | 五月天丁香亚洲 | www·22com天天操 | 国产精品毛片久久 | 97人人澡人人添人人爽超碰 | 97国产| 黄色字幕网 | 欧美一区免费在线观看 | 国产人成精品一区二区三 | 精品免费一区 | 国产在线高清精品 | 亚洲在线视频免费观看 | 97人人精品 | 黄色在线看网站 | 国内精品久久久久影院一蜜桃 | 国产精品国产三级国产专区53 | 欧美视频18 | 亚洲乱码久久 | 激情视频二区 | 亚洲精品一区中文字幕乱码 | 免费观看全黄做爰大片国产 | 天天色天天上天天操 | 免费国产在线精品 | 国产黄色在线观看 | 亚洲精品国产第一综合99久久 | 精品国产免费人成在线观看 | 久久久一本精品99久久精品 | 一二三久久久 | 一区二区av | 日韩成人精品在线观看 | a在线观看免费视频 | 久久婷婷丁香 | 97人人精品 | 亚洲国产欧美在线人成大黄瓜 | 91麻豆精品国产自产在线游戏 | 国产小视频在线免费观看视频 | 欧美日韩一区二区久久 | 91看片在线 | 久久久久免费 | 亚州免费视频 | 国产在线观看av | 亚洲婷婷免费 | 91视频亚洲 | 日韩久久电影 | aa一级片 | 免费在线黄 | 国产韩国精品一区二区三区 | 国产精品久久久免费看 | 国产一区二区在线免费 | 日韩高清毛片 | 欧美精品久久久久久久久久 | 国产精品99久久久精品免费观看 | 国产麻豆电影在线观看 | 日韩精品视频免费专区在线播放 | 最新高清无码专区 | a成人v在线 | 久久人人爽av | 狠狠久久综合 | 五月婷婷中文网 | 婷婷5月激情5月 | 国产精品国产亚洲精品看不卡 | 99精品国产高清在线观看 | 激情欧美在线观看 | 国产精品久久99综合免费观看尤物 | 国产剧情亚洲 | av视屏在线 | 国产精品黄色在线观看 | 97超碰资源网 | 国产日韩精品欧美 | 国产视频1区2区 | 香蕉视频免费看 | 日本午夜免费福利视频 | 国产精品久久久久久久久久久免费看 | 久久久国产99久久国产一 | 国产原创在线 | 香蕉国产91| 人人干狠狠干 | 丁香六月在线观看 | 正在播放 久久 | 最新在线你懂的 | 国产香蕉97碰碰碰视频在线观看 | 国产精品国产三级国产不产一地 | 天躁狠狠躁 | 在线亚洲激情 | 超碰97av在线 | 色5月婷婷| 精品一区二区三区电影 | 中文在线8新资源库 | 五月婷婷久久丁香 | 808电影 | 色综合天天天天做夜夜夜夜做 | 看污网站| 日日激情| 亚洲 综合 激情 | 久久婷婷开心 | 在线免费亚洲 | 久久91久久久久麻豆精品 | 99国产精品免费网站 | 91成人免费在线 | 日韩毛片一区 | 亚洲欧洲精品一区 | 在线观看黄色 | 国产成人黄色片 | 91看片在线免费观看 | av福利在线播放 | 三级小视频在线观看 | 国产一级淫片在线观看 | 国产视频18 | 最近最新最好看中文视频 | 日日夜夜天天干 | 美女视频久久 | 日韩经典一区二区三区 | 午夜影院先 | 国产一区二区在线播放视频 | 亚洲黄色一级电影 | 国产精品刺激对白麻豆99 | 2024国产精品视频 | 久草热视频 | 国产激情小视频在线观看 | 在线免费高清一区二区三区 | 国产专区精品 | 欧美一级片免费播放 | 黄色大片免费网站 | 国产精品大全 | 91成人免费在线 | 91网在线看 | 中文字幕韩在线第一页 | 免费av免费观看 | 最新91在线视频 | 99久久精品国产系列 | 亚洲精品久久久蜜桃 | 黄色亚洲在线 | 成年人电影毛片 | 久久9视频 | 国产精品嫩草影院123 | 成人久久综合 | 亚洲欧美偷拍另类 | 天天操狠狠操网站 | 激情丁香婷婷 | 国产精品毛片网 | 色视频网站在线观看一=区 a视频免费在线观看 | 超碰人人做 | 91新人在线观看 | 日韩成人黄色av | 精品国产大片 | 久久y| 国产九九热视频 | 亚洲码国产日韩欧美高潮在线播放 | 色综合天天综合 | 国产精品自产拍在线观看蜜 | 亚洲视频 在线观看 | 玖玖在线免费视频 | 日韩在线观看网址 | 国产精品影音先锋 | 综合网中文字幕 | 久久综合一本 | 成年人在线电影 | 黄色aaa级片 | av一区二区三区在线 | 色综合久久久久久久 | 国产在线一线 | 一级黄色a视频 | 97成人在线| 黄污在线看 | 成人黄视频 | 精品视频免费在线 | 中文字幕一区二区三区四区久久 | 成人免费视频网站在线观看 | 久久久久久久久久久久电影 | 欧美精品一区二区三区一线天视频 | 久久精品一二三 | 久久男人免费视频 | 国产精品美女在线观看 | 精品国产中文字幕 | 亚洲黄色在线看 | 在线电影日韩 | 又黄又爽又刺激视频 | 国产日韩精品在线观看 | 久久免费视频这里只有精品 | 久久久久色 | 亚洲欧美国产精品 | 麻豆传媒视频在线免费观看 | 欧美成a人片在线观看久 | 亚洲国产中文字幕 | 久久精品在线视频 | 99精品视频免费观看 | 欧美激情综合色 | 精品久久网 | 中文字幕一区二 | 在线视频 成人 | 久久免费美女视频 | 九九视频在线观看视频6 | 国产精品美女久久久久久久 | 亚洲区另类春色综合小说校园片 | 日韩天堂在线观看 | 日韩夜夜爽| 欧美一进一出抽搐大尺度视频 | 久久国产高清 | 欧美日韩另类在线观看 | 精品日韩视频 | 国产理论片在线观看 | 五月香视频在线观看 | 在线观看欧美成人 | 四季av综合网站 | 亚洲精品综合在线观看 | 欧亚久久 | 久久久资源 | 日韩在线观看你懂得 | 中文字幕综合在线 | 波多野结衣在线观看一区二区三区 | 黄色影院在线观看 | 久久精品视频观看 | 中文区中文字幕免费看 | 涩涩网站免费 | 欧美巨大荫蒂茸毛毛人妖 | 五月花激情 | 天天操天天操天天操天天操天天操天天操 | 懂色av一区二区三区蜜臀 | 日日夜夜精品免费观看 | 免费看的黄网站 | 五月天婷婷综合 | 久久99精品久久久久久秒播蜜臀 | 在线看日韩 | 免费看三级网站 | 久久精品视频在线观看 | 麻豆国产露脸在线观看 | 国产 在线 日韩 | 国产视频亚洲 | 一区二区三区免费播放 | 中文字幕 国产视频 | 天天五月天色 | 97电影院在线观看 | 中文字幕在线观看第二页 | 狠狠久久综合 | 黄色在线免费观看网址 | 久久久久久黄 | 一区二区在线影院 | 亚洲激情 在线 | 91九色视频网站 | 亚洲精品在线观看的 | 国产精品高清一区二区三区 | 玖玖玖在线观看 | 波多野结衣精品 | 中文字幕欧美日韩va免费视频 | 亚洲国产欧美在线人成大黄瓜 | 蜜桃视频成人在线观看 | 欧美成亚洲 | 欧美激情精品久久久久久免费印度 | 91禁看片| 人人盈棋牌 | 国产麻豆精品一区二区 | 久久久精品国产一区二区 | 久久久穴 | 国产精品免费观看在线 | 伊人激情网 | 亚洲www天堂com | 日本公妇色中文字幕 | 国产拍揄自揄精品视频麻豆 | 久久综合爱 | 久久激五月天综合精品 | 高清日韩一区二区 | 九九在线视频免费观看 | 国产高h视频 | 日韩在线视频网址 | 日本激情视频中文字幕 | 精品99免费视频 | 色婷婷狠| 国产精品黑丝在线观看 | 免费看黄的视频 | www激情com| 麻豆视频免费在线播放 | 国产黄色片免费 | 日韩中文字幕在线 | 亚一亚二国产专区 | 91av成人 | 一级黄色大片 | 激情视频在线高清看 | 中文av字幕在线观看 | 亚洲va欧美va人人爽 | 国产亚洲精品久久久久久 | 国产亚洲欧美在线视频 | 国产精品白丝jk白祙 | 中文字幕 第二区 | 97国产视频 | 久久天天躁夜夜躁狠狠85麻豆 | 亚洲片在线资源 | 亚洲精品视频免费在线观看 | 成人在线观看免费 | 国产精品久久久久国产精品日日 | 欧美性色网站 | 久久久久国产精品厨房 | 日日日操 | 有没有在线观看av | 国产亚洲精品成人av久久影院 | 日韩3区 | 成人一区二区三区在线 | 天天操天天色天天射 | 国产成人精品一区二区三区在线观看 | 欧洲一区精品 | 中文字幕在线一区二区三区 | 亚洲人成综合 | 成人免费在线视频 | 亚洲精品美女免费 | 有码中文字幕在线观看 | 日韩 精品 一区 国产 麻豆 | 日韩网站免费观看 | 干狠狠 | 国内精品久久久久久久久久清纯 | 久久精品国产精品亚洲 | 日韩在线播放欧美字幕 | 一区二区视频播放 | 欧美极品裸体 | 99久久精品费精品 | 九九九热精品免费视频观看 | 日韩免费一区二区三区 | 国产精品久久久久久麻豆一区 | 黄色av一区二区 | 欧美 日韩精品 | 久久影视一区二区 | 国产色女人 | 中文字幕美女免费在线 | 久99久中文字幕在线 | 中文字幕有码在线 | 五月婷婷操 | 久久久免费观看 | 久久一区国产 | 亚洲精品久久久久www | 在线色网站 | 九九热在线视频免费观看 | 欧美性色xo影院 | 亚洲精品午夜久久久久久久久久久 | a电影免费看 | 色狠狠一区二区 | av手机在线播放 | 国产一级在线观看 | 91久久丝袜国产露脸动漫 | 久久亚洲视频 | 精品福利av | 国内精品久久久久影院优 | 五月婷婷中文网 | 亚洲 欧美 国产 va在线影院 | 国产成人免费在线观看 | 天天射射天天 | 一本—道久久a久久精品蜜桃 | 很黄很污的视频网站 | 91漂亮少妇露脸在线播放 | 欧美一二三专区 | 国产网红在线 | 精品99在线观看 | 91久久偷偷做嫩草影院 | 不卡中文字幕av | 亚洲精品视频在线观看网站 | 国产精品情侣视频 | 欧美一级黄大片 | 成人在线视频免费看 | 中文字幕日本电影 | 免费色网站 | 日韩在线免费高清视频 | 国产精品久久久av久久久 | 国产二区免费视频 | 狠狠的操你 | 五月婷婷丁香 | 国产不卡在线视频 | 九色91福利 | 2024国产精品视频 | 一级片黄色片网站 | 99爱这里只有精品 | 久久久久福利视频 | 24小时日本在线www免费的 | 亚洲精品日韩在线观看 | 国产精品黑丝在线观看 | 国产精品成人一区二区 | 国产精品99久久久精品免费观看 | 日韩视频免费 | 欧美午夜寂寞影院 | 九九免费观看全部免费视频 | 少妇bbw撒尿 | 久久综合色综合88 | 黄色av播放 | 国产精品美女久久久久久久网站 | 最近中文字幕大全 | 久在线观看视频 | 日韩精品免费在线 | 久久久久久久久久久久久久av | 天天综合网久久综合网 | 亚洲国产视频在线 | 欧美与欧洲交xxxx免费观看 | 国产美女精品久久久 | 日韩精品不卡在线观看 | 色网站在线免费观看 | 91九色精品国产 | 最新国产精品亚洲 | 激情在线免费视频 | 久久久久久久影院 | 99久在线精品99re8热视频 | 日韩av中文字幕在线免费观看 | 国产成人精品999在线观看 | 美女视频免费精品 | 九九热久久免费视频 | 欧美日韩久久久 | 久久伊人八月婷婷综合激情 | 91丨九色丨国产在线观看 | 国产一区二区免费看 | 亚洲一区二区高潮无套美女 | 久久精品永久免费 | 国产成人三级一区二区在线观看一 | 久久亚洲精品电影 | 欧美国产日韩一区二区 | 在线成人免费av | 人人模人人爽 | 国产99自拍 | 18岁免费看片| 色综合久久久久 | 久久久久综合视频 | 天堂av色婷婷一区二区三区 | 狠狠狠色丁香综合久久天下网 | 欧美少妇bbwhd| 日韩精品一区二区三区三炮视频 | 97在线影视| 成人免费在线电影 | 亚洲国产小视频在线观看 | 久久精品视频在线观看 | 国产精品区二区三区日本 | 在线观看日韩一区 | 久久久99国产精品免费 | 久久久国产精品一区二区中文 | 欧美亚洲xxx | 亚洲美女视频网 | 欧美日韩在线视频免费 | 久久综合色一综合色88 | 综合网中文字幕 | 777久久久| 国产成人高清av | 亚洲精品高清视频在线观看 | 天天操人人要 | 美女免费视频观看网站 | 国产尤物在线视频 | 天天综合入口 | 久久久久久久久久免费 | 热久久精品在线 | 免费国产黄线在线观看视频 | 九九视频在线观看视频6 | 很黄很污的视频网站 | 久一久久 | 国产福利一区二区三区在线观看 | 亚洲精品www| 国产伦精品一区二区三区照片91 | 美女又爽又黄 | 欧洲在线免费视频 | 天天干 天天摸 天天操 | 超碰av在线免费观看 | 亚洲永久精品一区 | 久久中文欧美 | 日韩欧美精品在线 | 人人澡超碰碰97碰碰碰软件 | 欧美日韩综合在线观看 | 日韩成人免费在线 | 国产视频首页 | 国内久久久 | 综合色婷婷 | 香蕉影视在线观看 | 中文字幕在线播放一区 | 天天狠狠 | 久久亚洲免费视频 |