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
hasMany('app\model\Money', 'user_id', 'id'); } }
Money.php
belongsTo('app\model\User', 'user_id', 'id'); } }
主程序
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 '
'; $user = Money::find(1)->user; echo "用户模型数据:". $user->toJson() ; echo '
'; echo "使用查询构建器
"; $moneys = User::find(2)->moneys()->where("cny","<",1000)->get(); echo "帐号模型数据集合:". $moneys->toJson() ; echo '
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
- 主程序增加了使用查询构建器筛选的重要功能