Laravel DynamoDB Eloquent模型和查询构建器

2023-06-01 00:00:00 查询 模型 构建

Laravel DynamoDB 是一个基于 DynamoDB 的 Eloquent 模型和 Laravel 查询构建器。 

https://github.com/kitar/laravel-dynamodb

使用提供的 Dynamo 驱动程序,模型扩展了 Eloquent 基础模型:

use Kitar\Dynamodb\Model\Model;
 
class ProductCatalog extends Model
{
    // Required
    protected $table = 'ProductCatalog';
 
    // Name of the partition key (required)
    protected $primaryKey = 'Id';
 
    // Name of the sort key (optional)
    protected $sortKey = 'Subject';
 
    // Default sort key value when we
    // call find without a sort key.
    protected $sortKeyDefault = 'profile';
 
    protected $fillable = ['Id', 'Price', 'Title'];
}


以下是您可以使用此包的查询和操作的自述文件中的一些示例:

https://github.com/kitar/laravel-dynamodb#readme
// Get all models
$products = ProductCatalog::scan();
// or
$products = ProductCatalog::all();
 
// Paginated
$products = ProductCatalog::limit(5)->scan();
 
// Creating a user
$user = User::create([
    'email' => '[email protected]',
    // Sort key. If we don't specify this,
    // sortKeyDefault will be used.
    'type' => 'profile',
]);
 
// Instantiate a model and then save.
$user = new User([
    'email' => '[email protected]',
    'type' => 'profile'
]);
 
$user->save();
 
// Update an existing model
$user->update([
    'name' => 'foobar'
]);


这个包包括更高级的 Dynamo 用法,包括一个可以在没有模型的情况下使用的查询构建器(也可以在 Laravel 之外使用)。 

https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Expressions.ConditionExpressions.html

此外,查询生成器支持条件表达式等内容。 

例如:

DB::table('ProductCatalog')
    ->condition('Id', 'attribute_not_exists')
    ->orCondition('Price', 'attribute_not_exists')
    ->putItem([/*...*/]);


下面是一个过滤表达式的例子,

https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Query.html#Query.FilterExpression

它可以在从数据库返回结果之前用表达式过滤结果:


$response = DB::table('Thread')
    ->filter('LastPostedBy', '=', 'User A')
    ->scan();
 
// orFilter()
$response = DB::table('Thread')
    ->filter('LastPostedBy', '=', 'User A')
    ->orFilter('LastPostedBy', '=', 'User B')
    ->scan();
 
// filterIn
$response = DB::table('Thread')
    ->filterIn('LastPostedBy', ['User A', 'User B'])
    ->scan();
 
// filterBetween
$response = DB::table('ProductCatalog')
    ->filterBetween('Price', [0, 100])
    ->scan();


Laravel DynamoDB 包也有关于使用 DynamoDB 模型进行用户身份验证的详细说明。

 您可以了解有关此软件包的更多信息,获取完整的安装说明,并在 GitHub 上查看源代码。

https://github.com/kitar/laravel-dynamodb#authentication-with-model
https://github.com/kitar/laravel-dynamodb

转:

https://laravel-news.com/laravel-dynamod

相关文章