- 浏览: 841148 次
- 性别:
- 来自: 南京
-
文章分类
最新评论
-
xieye:
jetty插件有好几个版本,1.6,1.7,1.8
我选的是用 ...
tapestry入门(翻译)3 导入项目到eclipse -
xieye:
还有,
注:第2部分时,需要先安装jetty,我自己在安装过程 ...
tapestry入门(翻译)3 导入项目到eclipse -
xieye:
说明一下:实际使用中,导入时我并没有错误。2、我把eclips ...
tapestry入门(翻译)3 导入项目到eclipse -
xieye:
其实还是有一些先决条件的。1是外部环境,2是进步是阶段性的(意 ...
(转载文章)如何愉悦起来:一位精神治疗师的见解 -
mandy_yanzi:
我都已经饿7天了坚持为了我的衣衣
身体健康的问题
我的Eloquent单独使用系列文章
php的db类库Eloquent单独使用系列(1)
php的db类库Eloquent单独使用系列(2) - 分页
php的db类库Eloquent单独使用系列(3) - sql日志
php的db类库Eloquent单独使用系列(4)- 事件监听
php的db类库Eloquent单独使用系列(5)- 模型转数组
php的db类库Eloquent单独使用系列(6)- 一对一关联
php的db类库Eloquent单独使用系列(7)- 一对多关联
php的db类库Eloquent单独使用系列(8)- 多对多关联
php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身
php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多
php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性
php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2
本系列文章的目的就是脱离laravel环境使用Eloquent,因为它好用。
本系列文章所有代码均测试通过。Eloquent版本:5.4.27
本文的目的是使用一对多关联。
首先建表,users是用户表,moneys是帐号表,一个用户有多个帐户。
源代码
本文3个文件,主程序,user模型类,money模型类
User.php
Money.php
主程序
输出结果
以下是浏览器输出
总结
php的db类库Eloquent单独使用系列(1)
php的db类库Eloquent单独使用系列(2) - 分页
php的db类库Eloquent单独使用系列(3) - sql日志
php的db类库Eloquent单独使用系列(4)- 事件监听
php的db类库Eloquent单独使用系列(5)- 模型转数组
php的db类库Eloquent单独使用系列(6)- 一对一关联
php的db类库Eloquent单独使用系列(7)- 一对多关联
php的db类库Eloquent单独使用系列(8)- 多对多关联
php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身
php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多
php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性
php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2
本系列文章的目的就是脱离laravel环境使用Eloquent,因为它好用。
本系列文章所有代码均测试通过。Eloquent版本:5.4.27
本文的目的是使用一对多关联。
首先建表,users是用户表,moneys是帐号表,一个用户有多个帐户。
CREATE TABLE users ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(50) NOT NULL DEFAULT '' COMMENT '用户名称', age int(11) NOT NULL DEFAULT '0' COMMENT '年龄', PRIMARY KEY (id) ); CREATE TABLE moneys ( id int(11) NOT NULL AUTO_INCREMENT, user_id int not null default 0 comment '用户id主键', cny int NOT NULL DEFAULT '0' COMMENT '人民币', usd int NOT NULL DEFAULT '0' COMMENT '美元', PRIMARY KEY (id) );
源代码
本文3个文件,主程序,user模型类,money模型类
User.php
<?php namespace app\model; use \Illuminate\Database\Eloquent\Model; /** * User模型类 */ class User extends Model { protected $table = 'users'; public $timestamps = false; public function money() { // 重要说明:user_id是Money模型里的,id是User模型里的。 return $this->hasMany('app\model\Money', 'user_id', 'id'); } }
Money.php
<?php namespace app\model; use \Illuminate\Database\Eloquent\Model; /** * 账户模型类 */ class Money extends Model { protected $table = 'moneys'; public $timestamps = false; public function user() { // 重要说明:user_id是Money模型里的,id是User模型里的。 return $this->belongsTo('app\model\User', 'user_id', 'id'); } }
主程序
<?php namespace app\control; use Illuminate\Database\Capsule\Manager; use app\model\User; use app\model\Money; class Ill2 { /** * 主程序。 */ public function hook() { $db = new Manager (); $db->addConnection ( [ 'driver' => 'mysql', 'host' => '127.0.0.1', 'database' => 'test1', 'username' => 'root', 'password' => 'root', 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '' ] ); $db->setAsGlobal (); $db->bootEloquent (); $db::delete('delete from users '); $db::delete('delete from moneys '); $user = new User (); $user->name = 'user1'; $user->id = 1; $user->save (); // 新模型添加 $user = new User (); $user->name = 'user2'; $user->id = 2; $user->save (); // 新模型添加 $money = new Money(); $money->id = 1; $money->cny = 10; $money->usd = 20; $money->user_id = 2; $money->save (); // 新模型添加 $money = new Money(); $money->id = 2; $money->cny = 1000; $money->usd = 1000; $money->user_id = 2; $money->save (); // 新模型添加 // 要点:调用money方法时,不要加括号 $moneys = User::find(2)->moneys; echo "帐号模型数据集合:". $moneys->toJson() ; echo '<br>'; $user = Money::find(1)->user; echo "用户模型数据:". $user->toJson() ; echo '<br>'; echo "<h2>使用查询构建器</h2>"; $moneys = User::find(2)->moneys()->where("cny","<",1000)->get(); echo "帐号模型数据集合:". $moneys->toJson() ; echo '<br>all ok!'; } }
输出结果
以下是浏览器输出
帐号模型数据集合:[{"id":1,"user_id":2,"cny":10,"usd":20},{"id":2,"user_id":2,"cny":1000,"usd":1000}] 用户模型数据:{"id":2,"name":"user2","age":0} 使用查询构建器 帐号模型数据集合:[{"id":1,"user_id":2,"cny":10,"usd":20}] all ok!
总结
- 表结构没有任何变化。
- 账户模型类与前文相同,用户模型类略改,hasOne改成hasMany
- 主程序增加了使用查询构建器筛选的重要功能
发表评论
-
召唤神龙 - 安装 centos 8, php 8, mysql 8, laravel 8 的整套 php 运行环境
2020-11-27 16:26 738本文编写时间:2020-11-27 传说集齐龙珠可以召唤神 ... -
centos8 使用阿里镜像快速安装php7.4套件
2020-11-15 00:48 900centos8 使用阿里镜像快速安装php7.4套件 本文只 ... -
centos7 使用阿里镜像快速安装php7.4套件
2020-11-15 00:32 1289本文只考虑centos7 今日 2020-11-16 rem ... -
composer常用命令
2020-11-05 14:46 1511列出当前全局配置 composer config -l -g ... -
期待centos8+php8 + mysql8 + laravel8,8888
2020-10-29 19:24 551期待centos8+php8 + mysql8 目前主要使用 ... -
ubuntu 安装 php7.4以及各类插件
2020-10-24 13:20 1162ubuntu 安装 php7.4以及各类插件 安装系统 最近 ... -
宝塔定义站点
2020-02-24 10:41 2宝塔定义站点。 1111111111111111111111 ... -
让php-fpm以root账号运行
2020-02-19 21:41 838一般来说,我们没有这种需求,但是当需要时, 可以让php-fp ... -
将代码部署到coding.net
2020-01-10 14:20 669coding.net 是一个git仓库,有免费有收费。 首先 ... -
php部署工具deployer技巧 - vendor目录创建
2020-01-06 12:06 935deployer是个好东西,可是每次都composer ,其实 ... -
自定义redis多个实例
2020-01-04 01:17 662假如多个项目部署到同一台服务器,有时会被redis的各项目前缀 ... -
推荐使用php的部署工具 deployer
2020-01-03 16:48 951php部署代码可以使用 https://deployer.or ... -
使用composer 类库 cachetool 清除opcache 的缓存
2020-01-03 16:38 980php的生产服务器上,需要把opche打开。 但有时,会被缓 ... -
laravel容器学习体会
2019-12-31 15:11 694根据文档与实测结果 假设我在app下建一个Services目 ... -
phalcon 自定义超强日志类
2019-12-18 10:00 844phalcon自带的日志文件类,有两个麻烦之处。 1、路径不能 ... -
自定义后台的使用
2019-12-18 05:22 431如果自己写后台,保存用户的表单请求值 所有的情况如下: 1 ... -
phalcon 自定义事件使用的多种方式
2019-12-16 20:43 785方法1:官方文档的方式。 这是控制器: public ... -
phalcon对控制器返回值的使用以输出json
2019-12-16 19:17 854在phalcon里,控制器的Action的方法的返回值没啥用。 ... -
phalcon数据库DB使用实例
2019-12-12 17:12 715整理了一下phalcon的db使用,写了个demo。 ... -
php-redis5.0降级成php-redis4.3
2019-08-22 00:01 901最新版本的php的redis插件,版本是5.0 但是可能会有 ...
相关推荐
1. **安装扩展包**:通常我们可以使用`spatie/laravel-eloquent-has-many-deep`这个扩展包,它为Eloquent提供了对UUID的支持。通过Composer安装: ``` composer require spatie/laravel-eloquent-has-many-deep `...
此外,Eloquent还提供了查询构建器,用于构建和执行SQL查询,以及关系(Relationships)功能,用来处理一对多、一对一、多对多等复杂的数据库关联。 单一状态标记存储(Single State Marking Store)是一种设计模式...
Eloquent-Extended-Cast-Model库正是对这一特性的扩展,它使得开发者可以创建自定义的类型转换器,这些转换器可以处理更复杂的数据格式,如JSON、数组、甚至是其他自定义的序列化和反序列化逻辑。这在处理非标准数据...
例如,如果我们有一个`User`模型,它有一对多的`posts`关系,我们可以通过以下方式获取用户及其文章: ```php $user = User::find(1); foreach ($user->posts as $post) { // ... } ``` 当第一次访问`$user->posts...
这个压缩包“Laravel开发-eloquent-extended-cast-model .zip”很可能包含了一些关于如何扩展Eloquent模型的自定义类型转换(casts)的教程或示例代码。 Eloquent的模型类与数据库表一一对应,每个模型实例代表表中...
- 首先,你需要创建一个基础模型类,通常命名为`BaseModel`,并指定与之关联的数据库表。 - 然后,为每种类型创建一个子模型,如`UserModel`, `AdminModel`等,它们都继承自`BaseModel`。 - 在每个子模型中,可以...
使用Eloquent-Model-Generator的步骤可能包括以下几点: 1. 安装:首先,你需要将该工具通过Composer添加到你的Laravel项目的依赖中,通常使用`composer require`命令。 2. 配置:配置文件中,你需要指定数据库连接...
以上只是PHP开发中常用类库的一部分,实际开发中还有更多优秀的类库,如Laravel的Eloquent ORM、Guzzle HTTP客户端库等,它们极大地提高了开发效率和代码质量。了解并熟练使用这些类库,将使你的PHP开发工作更加...
ROS是一个用于在不同进程间匿名的发布、订阅、传递信息的中间件。 ROS2系统的核心部分是ROS网络(ROS Graph)。ROS网络是指在ROS系统中不同的节点间相互通信的连接关系。 ROS Graph这里翻译成了ROS网络,因为我觉得...
应用使用邮递员,失眠等用法$ git clone https://github.com/DanielArturoAlejoAlvarez/Eloquent-Relations-Laravel-7-and-MySQL[NAME APP]$ composer install$ copy .env.example .env$ php artisan key:generate$ ...
总之,`laravel-eloquent-mysqli` 项目旨在帮助开发者了解和实践在 Laravel 中使用 mysqli 驱动进行数据库操作,这对于那些需要充分利用 MySQL 扩展特性的项目来说,是一个有价值的资源。在实际开发中,根据项目需求...
Eloquent提供了简单、直观的方式来处理数据库中的数据,而"eloquent-sortable"则是一个扩展,它为Eloquent模型增加了排序功能,允许我们轻松地对数据库记录进行排序。这个扩展的使用大大简化了在应用程序中实现动态...
- `hasOne`, `hasMany`, `belongsTo`, `belongsToMany`:定义一对一、一对多、多对一和多对多的关系。 - `with`:用于预加载关联数据,减少N+1查询问题。 - `hasManyThrough`:定义通过中间表建立的多对多关系。 ...
文件名`eloquent-state-machine-master`表明这是一个关于Eloquent状态机的源代码仓库,可能包含了示例代码、配置文件、测试案例等内容。开发者可以深入研究这些文件,学习如何在实际项目中应用Eloquent State ...
composer require arcanedev/eloquent-search-map ``` 然后,在你的模型中引入并使用`Arcanedev\\Searchable\\Searchable` Trait: ```php use Arcanedev\\Searchable\\Searchable; class YourModel extends ...
通过定义一对一、一对多、多对多等关系,可以方便地获取关联数据。例如,定义一个`hasMany`关系: ```php public function posts() { return $this->hasMany(Post::class); } ``` 4. **事件系统**:Eloquent模型...
"Laravel开发-eloquent-mongodb-repository"的主题就是关于如何在Laravel中利用Eloquent ORM来与MongoDB进行交互的实践教程。 首先,我们需要安装Jenssegers/Laravel-MongoDB扩展包,这个扩展提供了Eloquent模型对...
总之,"Laravel开发-eloquent-postgres-uuids"项目提供了一个实用的指南,帮助开发者在Laravel和PostgreSQL环境下顺利地使用UUID作为Eloquent模型的主键,从而更好地适应现代Web开发的需求。通过遵循这些步骤,你...
`eloquent-filterable`库提供了一种方式,让我们能够基于请求参数动态地添加和组合多个Scope。这使得在API开发中尤为有用,因为你可以轻松地根据客户端传递的参数来过滤数据。 例如,假设我们有一个`Filterable` ...
Eloquent Filter是Laravel社区中广泛使用的一个扩展,它允许我们根据输入的筛选器动态地对Eloquent查询进行过滤,从而实现更加灵活的数据检索功能。本文将深入探讨Laravel Eloquent Filter的相关知识点,帮助开发者...