我来自 SQL Server 背景,并使用 ServiceStack 在 .NET 中试验 Redis。我并不是说 Redis 可以完全替代 SQL Server,但我只是想了解如何使用它的基本概念,以便了解我们可以在哪些地方充分利用它。
我正在努力解决我认为是一个非常基本的问题。我们有一个项目列表,这些项目维护在几个不同的数据存储中。为简单起见,假设项目的定义是基本的:整数 id 和字符串名称。我正在尝试执行以下操作:
- 存储项目
- 如果我们只知道它的 id,则检索一个项目
- 如果我们只知道它的 id,则覆盖现有项目
- 显示该特定类型的所有项目
这是我整理的一些代码:
public class DocumentRepositoryRedis
{
private static string DOCUMENT_ID_KEY_BASE = "document::id::";
public IQueryable<Document> GetAllDocuments()
{
IEnumerable<Document> documentsFromRedis;
using (var documents = new RedisClient("localhost").As<Document>())
{
documentsFromRedis = documents.GetAll();
}
return documentsFromRedis.AsQueryable();
}
public Document GetDocument(int id)
{
Document document = null;
using (var redisDocuments = new RedisClient("localhost").As<Document>())
{
var documentKey = GetKeyByID(document.ID);
if (documentKey != null)
document = redisDocuments.GetValue(documentKey);
}
return document;
}
public void SaveDocument(Document document)
{
using (var redisDocuments = new RedisClient("localhost").As<Document>())
{
var documentKey = GetKeyByID(document.ID);
redisDocuments.SetEntry(documentKey, document);
}
}
private string GetKeyByID(int id)
{
return DOCUMENT_ID_KEY_BASE + id.ToString();
}
}
这一切似乎都有效 - 除了 GetAllDocuments。无论我存储了多少文档,这都会返回 0 个文档。我究竟做错了什么?