【发布时间】:2011-09-17 06:58:38
【问题描述】:
是的,有 questions here 和 here 关于如何使用 dapper-dot-net 插入记录。然而,这些答案虽然内容丰富,但似乎并没有为我指明正确的方向。情况如下:将数据从 SqlServer 移动到 MySql。将记录读入IEnumerable<WTUser> 很容易,但我只是在插入时没有得到任何东西。一、'移动记录代码':
// moving data
Dim session As New Session(DataProvider.MSSql, "server", _
"database")
Dim resources As List(Of WTUser) = session.QueryReader(Of WTUser)("select * from tbl_resource")
session = New Session(DataProvider.MySql, "server", "database", _
"user", "p@$$w0rd")
// *edit* - corrected parameter notation with '@'
Dim strInsert = "INSERT INTO tbl_resource (ResourceName, ResourceRate, ResourceTypeID, ActiveYN) " & _
"VALUES (@ResourceName, @ResourceRate, @ResourceType, @ActiveYN)"
Dim recordCount = session.WriteData(Of WTUser)(strInsert, resources)
// session Methods
Public Function QueryReader(Of TEntity As {Class, New})(ByVal Command As String) _
As IEnumerable(Of TEntity)
Dim list As IEnumerable(Of TEntity)
Dim cnn As IDbConnection = dataAgent.NewConnection
list = cnn.Query(Of TEntity)(Command, Nothing, Nothing, True, 0, CommandType.Text).ToList()
Return list
End Function
Public Function WriteData(Of TEntity As {Class, New})(ByVal Command As String, ByVal Entities As IEnumerable(Of TEntity)) _
As Integer
Dim cnn As IDbConnection = dataAgent.NewConnection
// *edit* if I do this I get the correct properties, but no data inserted
//Return cnn.Execute(Command, New TEntity(), Nothing, 15, CommandType.Text)
// original Return statement
Return cnn.Execute(Command, Entities, Nothing, 15, CommandType.Text)
End Function
cnn.Query 和 cnn.Execute 调用 dapper 扩展方法。现在,WTUser 类(注意:列名从 SqlServer 中的“WindowsName”更改为 MySql 中的“ResourceName”,因此两个属性指向同一个字段):
Public Class WTUser
// edited for brevity - assume the following all have public get/set methods
Public ActiveYN As String
Public ResourceID As Integer
Public ResourceRate As Integer
Public ResourceType As Integer
Public WindowsName As String
Public ResourceName As String
End Class
我收到来自 dapper 的异常:“Dapper 不支持 WTUser。” DataMapper(dapper)中的这个方法:
private static Action<IDbCommand, object> CreateParamInfoGenerator(Type OwnerType)
{
string dmName = string.Format("ParamInfo{0}", Guid.NewGuid());
Type[] objTypes = new[] { typeof(IDbCommand), typeof(object) };
var dm = new DynamicMethod(dmName, null, objTypes, OwnerType, true); // << - here
// emit stuff
// dm is instanced, now ...
foreach (var prop in OwnerType.GetProperties().OrderBy(p => p.Name))
此时 OwnerType =
System.Collections.Generic.List`1[[CRMBackEnd.WTUser, CRMBE,版本=1.0.0.0, 文化=中性, PublicKeyToken=null]], mscorlib, 版本=2.0.0.0,文化=中性, PublicKeyToken=b77a5c561934e089
看来 OwnerType 应该是 CRMBackEnd.WTUser ... 而不是 List<CRMBackEnd.WTUser> ... ???因为正在发生的事情是正在迭代集合属性:计数、容量等。我错过了什么?
更新
如果我将 session.WriteData 修改为:
Public Function WriteData(Of TEntity As {Class, New})(ByVal Command As String, _
ByVal Entities As IEnumerable(Of TEntity)) _
As Integer
Dim cnn As IDbConnection = dataAgent.NewConnection
Dim records As Integer
For Each entity As TEntity In Entities
records += cnn.Execute(Command, entity, Nothing, 15, CommandType.Text)
Next
Return records
End Function
记录被很好地插入......但我认为这不是必要的,例如:
connection.Execute(@"insert MyTable(colA, colB) values (@a, @b)",
new[] { new { a=1, b=1 }, new { a=2, b=2 }, new { a=3, b=3 } }
).IsEqualTo(3); // 3 rows inserted: "1,1", "2,2" and "3,3"
...来自dapper-dot-net
【问题讨论】: