我正在使用 Asp.Net MVC 构建一个简单的博客应用程序,我想使用 Redis 数据库。
我为我的用户类创建了一个存储库,其中包含一些方法(创建、getbyid 和更新)。问题是 GetById(long id) 方法。
using System;
using System.Collections.Generic;
using System.Text;
using ServiceStack.Redis;
using Domain.Entities;
using RedisDataLayer.AbstractRepository;
using System.Linq;
namespace RedisDataLayer.ConcreteRepository
{
public class UserRepository : IUserRepository
{
private readonly IRedisClient _redisClient;
public UserRepository(IRedisClient redisClient)
{
_redisClient = redisClient;
}
public User Create(User user)
{
var redisUsers = _redisClient.As<User>();
user.UserId = redisUsers.GetNextSequence();
redisUsers.Store(user);
return user;
}
public User GetById(long id)
{
var redisUsers = _redisClient.As<User>();
User returnUser;
returnUser = redisUsers.GetById(id);
return returnUser;
}
public User Update(User user)
{
var redisUsers = _redisClient.As<User>();
User savedUser = redisUsers.GetById(user.UserId);
savedUser.Username = user.Username;
savedUser.Password = user.Password;
savedUser.UserId = user.UserId;
foreach (var blogId in user.BlogIds)
{
savedUser.BlogIds.Add(blogId);
}
redisUsers.Store(savedUser);
return savedUser;
}
}
}
为什么这个方法 returnUser = redisUsers.GetById(id);
总是返回 null?我一直试图在 StackOverflow 和其他地方找到答案,但我找不到。
最佳答案
GetById()
API(以及所有其他 ServiceStack.Redis 类型化客户端 API)期望 POCO 在 Id
属性中具有唯一的 Id。
因此,您应该更改用户模型以使用 Id
而不是 UserId
。
关于c# - 为什么 Redis C# 客户端方法 .getById() 返回 null?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52104436/