Laravel DynamoDB Eloquent模型和查询构建器
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
相关文章