与Dapper的身份。
我的身份中的用户属于IUser< int>
当用户注册时,我在AccountController中创建了一个用户:
注册POST:
if (ModelState.IsValid)
{
user = new MySiteUserRecord
{
UserName = model.UserName,
AccessFailedCount = 0,
ApplicationName = "Portal",
Description = string.Empty,
PhoneNumber = model.PhoneNumber ?? string.Empty,
Email = model.Email
};
var result = await UserManager.CreateAsync(user, model.Password);
if (result.Succeeded)
{
...
如果成功,我需要获取新创建的用户记录,因为上面的“新”用户类不知道它的ID是什么......
user = await UserManager.FindByNameAsync(model.UserName);
当我查看此找到的用户记录时,user.Id = 0。 但是如果我查看数据库,这个新创建的用户的行就是下一个Id,例如9 即使我执行直接Db查询,而不是使用UserManager的FindByNameAsync函数,返回的Id始终为0.
我真的很难过 - 我可能错过了一些东西......
如何通过分配的数据库ID获取用户记录?
编辑:我的查找用户功能是:
Task<MySiteUserRecord> IUserStore<MySiteUserRecord, int>.FindByNameAsync(string userName)
{
var predicate = Predicates.Field<MySiteUserRecord>(f => f.UserName, Operator.Eq, userName);
return Task.Factory.StartNew(() => _sqlConn.GetList<MySiteUserRecord>(predicate).FirstOrDefault());
}
答案 0 :(得分:0)
我的用户类的映射器类专门告诉DapperExtensions忽略我的ID字段。使用其他Dapper扩展时必须要小心,并且需要研究它们如何与您的系统交互。