[size=x-large]我的Eloquent单独使用系列文章[/size]
[url=http://xieye.iteye.com/blog/2382907]php的db类库Eloquent单独使用系列(1)[/url]
[url=http://xieye.iteye.com/blog/2383390]php的db类库Eloquent单独使用系列(2) - 分页[/url]
[url=http://xieye.iteye.com/blog/2387809]php的db类库Eloquent单独使用系列(3) - sql日志[/url]
[url=http://xieye.iteye.com/blog/2387983]php的db类库Eloquent单独使用系列(4)- 事件监听[/url]
[url=http://xieye.iteye.com/blog/2383466]php的db类库Eloquent单独使用系列(5)- 模型转数组[/url]
[url=http://xieye.iteye.com/blog/2388023]php的db类库Eloquent单独使用系列(6)- 一对一关联[/url]
[url=http://xieye.iteye.com/blog/2388029]php的db类库Eloquent单独使用系列(7)- 一对多关联[/url]
[url=http://xieye.iteye.com/blog/2388150]php的db类库Eloquent单独使用系列(8)- 多对多关联[/url]
[url=http://xieye.iteye.com/blog/2388162]php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身[/url]
[url=http://xieye.iteye.com/blog/2388280]php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多[/url]
[url=http://xieye.iteye.com/blog/2388521]php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性[/url]
[url=http://xieye.iteye.com/blog/2389182]php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2[/url]
本系列文章的[b]目的[/b]就是脱离laravel环境使用Eloquent,因为它好用。
本系列文章所有代码均测试通过。Eloquent版本:5.4.27
本文的目的是使用一对多关联。
首先建表,users是用户表,moneys是帐号表,一个用户有多个帐户。
[size=x-large]源代码[/size]
本文3个文件,主程序,user模型类,money模型类
User.php
Money.php
主程序
[size=x-large]输出结果[/size]
以下是浏览器输出
[size=x-large]总结[/size]
[list]
[*]表结构没有任何变化。
[*]账户模型类与前文相同,用户模型类略改,hasOne改成hasMany
[*]主程序增加了使用查询构建器筛选的重要功能
[/list]
[url=http://xieye.iteye.com/blog/2382907]php的db类库Eloquent单独使用系列(1)[/url]
[url=http://xieye.iteye.com/blog/2383390]php的db类库Eloquent单独使用系列(2) - 分页[/url]
[url=http://xieye.iteye.com/blog/2387809]php的db类库Eloquent单独使用系列(3) - sql日志[/url]
[url=http://xieye.iteye.com/blog/2387983]php的db类库Eloquent单独使用系列(4)- 事件监听[/url]
[url=http://xieye.iteye.com/blog/2383466]php的db类库Eloquent单独使用系列(5)- 模型转数组[/url]
[url=http://xieye.iteye.com/blog/2388023]php的db类库Eloquent单独使用系列(6)- 一对一关联[/url]
[url=http://xieye.iteye.com/blog/2388029]php的db类库Eloquent单独使用系列(7)- 一对多关联[/url]
[url=http://xieye.iteye.com/blog/2388150]php的db类库Eloquent单独使用系列(8)- 多对多关联[/url]
[url=http://xieye.iteye.com/blog/2388162]php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身[/url]
[url=http://xieye.iteye.com/blog/2388280]php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多[/url]
[url=http://xieye.iteye.com/blog/2388521]php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性[/url]
[url=http://xieye.iteye.com/blog/2389182]php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2[/url]
本系列文章的[b]目的[/b]就是脱离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)
);
[size=x-large]源代码[/size]
本文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!';
}
}
[size=x-large]输出结果[/size]
以下是浏览器输出
帐号模型数据集合:[{"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!
[size=x-large]总结[/size]
[list]
[*]表结构没有任何变化。
[*]账户模型类与前文相同,用户模型类略改,hasOne改成hasMany
[*]主程序增加了使用查询构建器筛选的重要功能
[/list]