侯体宗的博客
  • 首页
  • Hyperf2.1版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Laravel DynamoDB Eloquent模型和查询构建器

Laravel  /  管理员 发布于 1个月前   72

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' => 'foo@bar.com',
    // Sort key. If we don't specify this,
    // sortKeyDefault will be used.
    'type' => 'profile',
]);
 
// Instantiate a model and then save.
$user = new User([
    'email' => 'foo@bar.com',
    '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


  • 上一条:
    上个世纪程序员被解雇后“报复方案”被曝光了
    下一条:
    Dcat-admin添加Excel导入功能
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • TP(3/5)
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel 9.13版本发布(0个评论)
    • Laravel角色和权限:拦截器Gates和策略Policies的解释(0个评论)
    • Laravel 9.12版本发布(0个评论)
    • laravel8框架集成RabbitMQ队列驱动程序(0个评论)
    • laravel框架应用拦截器:Laravel Gates(0个评论)
    • 近期文章
    • Laravel 9.13版本发布(0个评论)
    • beego+GeoLite2免费数据库获取ip地址经纬度等定位归属信息(0个评论)
    • redis安全配置之修改端口、添加密码流程步骤及启动使用(0个评论)
    • PHP + Memcache实现简单的统计当前在线人数功能(0个评论)
    • Thinkphp5.1框架中实现Session+Redis会话共享流程步骤(0个评论)
    • go语言中使用Signbit()函数判断一个整数是正数或负数(0个评论)
    • 删库跑路之一链家程序员删除公司9TB数据被判7年,望各大码农警之!(0个评论)
    • Laravel角色和权限:拦截器Gates和策略Policies的解释(0个评论)
    • Laravel 9.12版本发布(0个评论)
    • go语言中实现把数据写入文件函数WriteFile()编写(0个评论)
    • 近期评论
    • 博主 在

      hyperf框架常用命令-在centos7中退出命令及在docker容器中退出命令中评论 @路过的靓仔:cdn静态资源被墙,已修复..
    • GGGGGGGGG 在

      layui框架常用输入框介绍中评论 写的很好解决问题..
    • 路过的靓仔 在

      hyperf框架常用命令-在centos7中退出命令及在docker容器中退出命令中评论 剩下好多 wait 状态的..
    • 激光豆芽 在

      为什么你不能安逸?国内996为什么没有国外955香?中评论 国内现在无意义的内卷太多了..
    • 激光豆芽 在

      阿里云香港服务器搭建自用vpn:Shadowsocks使用流程步骤中评论 厉害了..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-01
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客