之前在和老何谈论他的开源项目Util中使用MySql的过程中发现了官方dapper在转换guid到string时候的一个错误
Error parsing column 0 (ID=6c2adb93-d81a-4fda-8e25-c6e90d4ebaaa - Object)
在官方github提了issue但一直没有给到更新和回复,其实解决方案也是非常简单的,利用dapper的TypeHandler处理下转换的过程即可
public class StringGuidHandler:SqlMapper.TypeHandler<string>
{
public override void SetValue(IDbDataParameter parameter, string value)
{
parameter.Value = value;
} public override string Parse(object value)
{
return value.ToString();
}
}
之后全局加入即可(此处为了方便以console为例)
using Dapper;
using System;
using System.Data.SqlClient; namespace GuidDemo
{
class Program
{
static void Main(string[] args)
{
try
{
SqlMapper.AddTypeHandler(typeof(string), new StringGuidHandler());
string sqlString = "server=192.168.1.3;uid=sa;pwd=demo$;database=demo;";
using (SqlConnection conn = new SqlConnection(sqlString))
{
conn.Open();//打开连接 string strSql = @"SELECT * from Test_002 WHERE Name='sa'"; Test_002 count = conn.QueryFirst<Test_002>(strSql); var testObject=new Test_002(){ID =Guid.NewGuid().ToString(),Name = "b"};
conn.Execute($"insert into Test_002 (Id,Name) values ({testObject.ID},{testObject.Name})"); }
}
catch(Exception e)
{ }
}
}
} using System.Data;
using Dapper; namespace GuidDemo
{
public class StringGuidHandler:SqlMapper.TypeHandler<string>
{
public override void SetValue(IDbDataParameter parameter, string value)
{
parameter.Value = value;
} public override string Parse(object value)
{
return value.ToString();
}
}
}