You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
abp/docs/zh-Hans/Blob-Storing-Database.md

4.5 KiB

BLOB存储数据库提供程序

BLOB存储数据库提供程序可以将BLOB存储在关系或非关系数据库中.

有两个数据库提供程序实现;

阅读BLOB存储文档了解如何使用BLOB存储系统. 本文档仅介绍如何为容器配置数据库提供程序.

安装

自动安装

如果你已基于应用程序启动模板创建了解决方案,则可以使用 abp add-module CLI命令将相关软件包自动添加到解决方案中.

在包含解决方案(.sln)文件的文件夹中打开命令行运行以下命令:

abp add-module Volo.Abp.BlobStoring.Database

此命令将所有NuGet软件包添加到解决方案的相应层. 如果使用的是EF Core,它会添加必要的配置,添加新的数据库迁移并更新数据库.

手动安装

这里是此提供程序定义的所有包:

你可以只安装 Volo.Abp.BlobStoring.Database.EntityFrameworkCoreVolo.Abp.BlobStoring.Database.MongoDB (根据你的偏好),因为它们依赖其他包.

安装完成后,添加 DepenedsOn 属性到相关模块.下面是由上面列出的相关NuGet包定义的模块类列表:

  • BlobStoringDatabaseDomainModule
  • BlobStoringDatabaseDomainSharedModule
  • BlobStoringDatabaseEntityFrameworkCoreModule
  • BlobStoringDatabaseMongoDbModule

如果你正在使用EF Core,还需要配置你的Migration DbContext将BLOB存储表添加到你的数据库. 在 OnModelCreating 方法中调用 builder.ConfigureBlobStoring() 扩展方法来包含到DbContext的映射. 你可以使用标准的 Add-MigrationUpdate-Database 命令在数据库中创建必要的表.

配置

连接字符串

如果你要使用你的 Default 连接字符串,则不需要做任何其他配置.

如果要将BLOB存储到单独的数据库,请在配置文件(appsettings.json)中将 AbpBlobStoring 用作连接字符串名称. 请阅读EF Core Migrations文档了解如何为所需模块创建和使用其他数据库.

配置容器

如果只使用数据库存储提供程序,则不需要手动配置,因为它是自动完成的. 如果使用多个存储提供程序,可能需要对其进行配置.

如同BLOB存储文档所述,配置是在模块类的 ConfigureServices 方法完成的.

示例: 配置为默认使用数据库系统存储提供程序

Configure<AbpBlobStoringOptions>(options =>
{
    options.Containers.ConfigureDefault(container =>
    {
        container.UseDatabase();
    });
});

参阅BLOB存储文档 学习如何为指定容器配置提供程序.

附加信息

它需要使用BLOB存储服务来使用BLOB存储系统. 但是如果要处理数据库表/实体,可以使用以下信息.

实体

此模块定义的实体:

  • DatabaseBlobContainer (aggregate root) 表示存储在数据库中的容器.
  • DatabaseBlob (aggregate root) 表示数据库中的BLOB.

参阅实体文档了解什么是实体和聚合根.

仓储

  • IDatabaseBlobContainerRepository
  • IDatabaseBlobRepository

你还可以使用 IRepositoryIRepository 来获得 IQueryable 能力. 更多信息请参阅仓储文档.

其他服务

  • DatabaseBlobProvider 是实现数据库BLOB存储提供程序的主要服务,如果你想要通过依赖注入覆盖/替换它(不要替换 IBlobProvider 接口,而是替换 DatabaseBlobProvider 类).