Devlooped.TableStorage.Protobuf 5.2.0

前缀已保留
dotnet add package Devlooped.TableStorage.Protobuf --version 5.2.0                
NuGet\Install-Package Devlooped.TableStorage.Protobuf -Version 5.2.0                
此命令 intended 用于在Visual Studio的包管理器控制台中,因为它使用NuGet模块的版本 Install-Package.
<PackageReference Include="Devlooped.TableStorage.Protobuf" Version="5.2.0" />                
对于支持 PackageReference 的项目,请复制此子节点到项目文件以引用程序包。
paket add Devlooped.TableStorage.Protobuf --version 5.2.0                
#r "nuget: Devlooped.TableStorage.Protobuf, 5.2.0"                
#r 指令可以用于F#交互式和Polyglot笔记本。将其复制到交互式工具或脚本的源代码中以引用程序包。
// Install Devlooped.TableStorage.Protobuf as a Cake Addin
#addin nuget:?package=Devlooped.TableStorage.Protobuf&version=5.2.0

// Install Devlooped.TableStorage.Protobuf as a Cake Tool
#tool nuget:?package=Devlooped.TableStorage.Protobuf&version=5.2.0                

这是一种用于文档型仓库的Protocol Buffers二进制序列化程序。

用法

  var repo = DocumentRepository.Create<Product>(..., serializer: ProtobufDocumentSerializer.Default);

文档存储

DocumentRepository.CreateDocumentPartition.Create 工厂方法提供对文档型存储的访问,提供类似于基于列的存储的API。

文档仓库导致实体以单个文档列的形式持久化,同时带有类型和版本信息,以便在应用程序级别处理版本控制。

API 与基于列的仓库的API大多相同(文档仓库实现了相同的底层 ITableStorage 接口)

public record Product(string Category, string Id) 
{
  public string? Title { get; init; }
  public double Price { get; init; }
  public DateOnly CreatedAt { get; init; }
}

var book = new Product("book", "9781473217386")
{
    Title = "Neuromancer",
    Price = 7.32
};

// Column-based storage
var repo = TableRepository.Create<Product>(
    CloudStorageAccount.DevelopmentStorageAccount,
    tableName: "Products",
    partitionKey: p => p.Category,
    rowKey: p => p.Id);

await repo.PutAsync(book);

// Document-based storage
var docs = DocumentRepository.Create<Product>(
    CloudStorageAccount.DevelopmentStorageAccount,
    tableName: "Documents",
    partitionKey: p => p.Category,
    rowKey: p => p.Id
    serializer: [SERIALIZER]);

await docs.PutAsync(book);

如果没有提供,序列化程序默认使用基于 System.Text.JsonDocumentSerializer.Default

存储差异的结果可以在以下Azure Storage Explorer的截图中看到。

Screenshot of entity persisted with separate columns for properties

Screenshot of entity persisted as a document

在文档表中持久化的Type列是持久化实体的Type.FullName,而Version是其程序集的[主版本].[次版本],这可以用于高级数据迁移场景。主版本和次版本组件也作为单独的列提供,以便通过使用IDocumentRepository.EnumerateAsync(predicate)更容易地查询各种版本范围。

赞助商

Clarius Org Kirill Osenkov MFB Technologies, Inc. Stephen Shaw Torutek DRIVE.NET, Inc. Ashley Medway Keith Pickford Thomas Bolon Kori Francis Toni Wenzel Giorgi Dalakishvili Uno Platform Dan Siegel Reuben Swartz Jacob Foshee alternate text is missing from this package README image Eric Johnson Ix Technologies B.V. David JENNI Jonathan Oleg Kyrylchuk Charley Wu Jakob Tikjøb Andersen Seann Alexander Tino Hager Mark Seemann Ken Bonny Simon Cropp agileworks-eu sorahex Zheyu Shen Vezel ChilliCream 4OTC

赞助此项目  

了解更多关于GitHub赞助商的信息

产品 兼容的和额外的计算目标框架版本。
.NET net5.0 已计算。 net5.0-windows 已计算。 net6.0 兼容。 net6.0-android 已计算。 net6.0-ios 已计算。 net6.0-maccatalyst 已计算。 net6.0-macos 已计算。 net6.0-tvos 已计算。 net6.0-windows 已计算。 net7.0 已计算。 net7.0-android 已计算。 net7.0-ios 已计算。 net7.0-maccatalyst 已计算。 net7.0-macos 已计算。 net7.0-tvos 已计算。 net7.0-windows 已计算。 net8.0 已计算。 net8.0-android 已计算。 net8.0-browser 已计算。 net8.0-ios 已计算。 net8.0-maccatalyst 已计算。 net8.0-macos 已计算。 net8.0-tvos 已计算。 net8.0-windows 已计算。
.NET Core netcoreapp2.0 已计算。 netcoreapp2.1 已计算。 netcoreapp2.2 已计算。 netcoreapp3.0 已计算。 netcoreapp3.1 已计算。
.NET 标准 netstandard2.0 兼容。 netstandard2.1 已计算。
.NET 框架 net461 已计算。 net462 已计算。 net463 已计算。 net47 已计算。 net471 已计算。 net472 已计算。 net48 已计算。 net481 已计算。
MonoAndroid monoandroid 已计算。
MonoMac monomac 已计算。
MonoTouch monotouch 已计算。
Tizen tizen40 已计算。 tizen60 已计算。
Xamarin.iOS xamarinios 已计算。
Xamarin.Mac xamarinmac 已计算。
Xamarin.TVOS xamarintvos 已计算。
Xamarin.WatchOS xamarinwatchos 已计算。
兼容的目标框架
包含的目标框架(在包内)
了解更多关于 目标框架.NET 标准

NuGet 包

此包不被任何 NuGet 包使用。

GitHub 代码仓库

此包不被任何流行的 GitHub 代码仓库使用。

版本 下载 最后更新
5.2.0 44 7/24/2024
5.2.0-rc.1 44 7/13/2024
5.2.0-rc 61 7/10/2024
5.2.0-beta 70 7/6/2024
5.1.2 119 1/25/2024
5.1.1 154 10/4/2023
5.1.0 180 8/11/2023
5.0.2 159 8/8/2023
5.0.1 158 7/25/2023
5.0.0 154 7/25/2023
4.3.1 157 7/24/2023
4.3.0 155 6/27/2023
4.2.1 182 4/17/2023
4.2.0 228 3/28/2023
4.1.3 295 1/20/2023
4.1.2 290 1/16/2023
4.0.0 414 8/26/2022
4.0.0-rc.1 96 8/26/2022
4.0.0-rc 168 8/15/2022
4.0.0-beta 183 5/17/2022
4.0.0-alpha 165 5/4/2022
3.2.0 569 12/13/2021
3.1.1 410 8/29/2021
3.1.0 370 8/13/2021
3.0.3 416 7/28/2021
3.0.2 424 7/1/2021
3.0.1 436 7/1/2021
3.0.0 417 7/1/2021
2.0.2 473 6/23/2021
2.0.1 444 6/17/2021
2.0.0 484 6/16/2021
1.3.0 387 5/31/2021