我的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是帐号表,一个用户必须且只能有一个帐户。
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->hasOne('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 Ill
{
/**
* 主程序。
*/
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方法时,不要加括号
$money = User::find(2)->money;
echo "帐号模型数据:". $money->toJson() ;
echo '<br>';
$user = Money::find(1)->user;
echo "用户模型数据:". $user->toJson() ;
echo '<br>';
echo '<br>all ok!';
}
}
输出结果
以下是浏览器输出
帐号模型数据:{"id":1,"user_id":2,"cny":10,"usd":20}
用户模型数据:{"id":2,"name":"user2","age":0}
all ok!
总结
- 独立的表,没有依赖性的,使用hasOne。
- 而有外键的表,使用belongsTo方法
- 在调用模型类时,没什么区别,只是把方法后的括号去掉,即可获得关联的模型!
分享到:
相关推荐
6. **使用HasManyDeep**:在处理深层次关联时,`spatie/laravel-eloquent-has-many-deep`扩展包非常有用,可以简化复杂的多级关联查询。 综上所述,"Laravel开发-eloquent-uuid-for-key"涵盖了将Eloquent模型的主键...
Eloquent-Extended-Cast-Model库正是对这一特性的扩展,它使得开发者可以创建自定义的类型转换器,这些转换器可以处理更复杂的数据格式,如JSON、数组、甚至是其他自定义的序列化和反序列化逻辑。这在处理非标准数据...
此外,Eloquent还提供了查询构建器,用于构建和执行SQL查询,以及关系(Relationships)功能,用来处理一对多、一对一、多对多等复杂的数据库关联。 单一状态标记存储(Single State Marking Store)是一种设计模式...
例如,如果我们有一个`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. 配置:配置文件中,你需要指定数据库连接...
ROS是一个用于在不同进程间匿名的发布、订阅、传递信息的中间件。 ROS2系统的核心部分是ROS网络(ROS Graph)。ROS网络是指在ROS系统中不同的节点间相互通信的连接关系。 ROS Graph这里翻译成了ROS网络,因为我觉得...
以上只是PHP开发中常用类库的一部分,实际开发中还有更多优秀的类库,如Laravel的Eloquent ORM、Guzzle HTTP客户端库等,它们极大地提高了开发效率和代码质量。了解并熟练使用这些类库,将使你的PHP开发工作更加...
总之,`laravel-eloquent-mysqli` 项目旨在帮助开发者了解和实践在 Laravel 中使用 mysqli 驱动进行数据库操作,这对于那些需要充分利用 MySQL 扩展特性的项目来说,是一个有价值的资源。在实际开发中,根据项目需求...
Eloquent提供了简单、直观的方式来处理数据库中的数据,而"eloquent-sortable"则是一个扩展,它为Eloquent模型增加了排序功能,允许我们轻松地对数据库记录进行排序。这个扩展的使用大大简化了在应用程序中实现动态...
"Laravel开发-eloquent-base-model" 主题聚焦于Eloquent ORM中的基础模型(Base Model),它是所有自定义模型类的基类,为开发者提供了许多便利的功能和接口。 Eloquent Base Model位于`Illuminate\Database\...
文件名`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 ...
应用使用邮递员,失眠等用法$ git clone https://github.com/DanielArturoAlejoAlvarez/Eloquent-Relations-Laravel-7-and-MySQL[NAME APP]$ composer install$ copy .env.example .env$ php artisan key:generate$ ...
通过定义一对一、一对多、多对多等关系,可以方便地获取关联数据。例如,定义一个`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开发的需求。通过遵循这些步骤,你...
$ git clone https://github.com/DanielArturoAlejoAlvarez/Eloquent-ORM-Laravel-8.5-Relationships-Advanced[NAME APP] $ composer install $ copy .env.example .env $ php artisan key:generate $ php artisan ...