与 Dapper 的身份。
我的身份中的用户属于 IUser< int > 类型
当用户注册时,我在我的 AccountController 中创建一个用户:
注册帖子:
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。但是如果我查看 DB,这个新创建的用户的行是下一个 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());
}