php json orm,ThinkPHP:JSON字段范例的运用(ORM)_PHP开发框架教程

3b718810ac6f385153f59b5cbc16c172.png

ThinkPHP5.1版本正式宣布已有一段时间了,我会连续给人人引见个中的新特征。本日要给人人引见的是一个大概许多用户还不相识的一个特征:JSON字段数据支撑。

不过起首注重一点,本篇内容中形貌的JSON字段数据的支撑是从V5.1.4+版本引入的。因为包含平安更新的缘由,发起确保运用5.1.9+版本。

本篇中对JSON字段的定义包含JSON范例或许保留的数据为JSON花样的字符范例,所以理论上除了运用JSON字段前提查询外,对数据库范例和版本没有请求。

Db类操纵JSON

假如你没有运用模子类,Db类供应了一个json要领能够指定你的数据表JSON花样字段。比方你的user表有一个info字段是JSON范例的,你能够运用下面的体式格局操纵数据。

数据写入

$user['name'] = 'thinkphp';

$user['info'] = [

'email' => 'thinkphp@qq.com',

'nickname' => '流年',

];

Db::name('user')

->json(['info'])

->insert($user);

json要领的参数是一个数组,示例中指定了info字段,实在能够指定多个JSON范例字段。

数据查询

查询全部JSON数据运用。

$user = Db::name('user')

->json(['info'])

->find(1);

dump($user);

返回的查询效果数据中,会自动包含一个数组范例的info数据,也就是说JSON花样数据已自动json_decode处置惩罚。

该体式格局查询对info字段并不是严格请求运用JSON范例

假如须要依据JSON数据的值举行查询,能够运用下面的要领

$user = Db::name('user')

->json(['info'])

->where('info->nickname','ThinkPHP')

->find();

dump($user);

请求info字段必需是JSON范例,MySQL须要5.7+版本才支撑

固然,也能够支撑多级

$user = Db::name('user')

->json(['info'])

->where('info->profile->nickname','ThinkPHP')

->find();

dump($user);

因为JSON字段的属性范例并不会自动猎取,所以,假如是整型数据查询的话,须要手动参数绑定,比方:

$user = Db::name('user')

->json(['info'])

->where('info->user_id', ':user_id')

->bind(['user_id' => [10, \PDO::PARAM_INT]])

->find();

dump($user);

数据更新

完全JSON数据更新

$data['info'] = [

'email' => 'kancloud@qq.com',

'nickname' => 'kancloud',

];

Db::name('user')

->json(['info'])

->where('id',1)

->update($data);

该体式格局查询对info字段并不是严格请求运用JSON范例

假如只是更新JSON数据中的某个值,则能够运用下面的要领:

$data['info->nickname'] = 'ThinkPHP';

Db::name('user')

->json(['info'])

->where('id',1)

->update($data);

一样请求info字段必需是JSON范例

模子操纵JSON数据

假如你运用的是模子操纵数据库的话,那末JSON数据操纵就更简朴了。

我们只要给User模子类增添一个json属性定义即可。

namespace app\index\model;

use think\Model;

class User extends Model

{

// 设置json范例字段

protected $json = ['info'];

}

json属性一样支撑定义多个字段称号,定义后,能够举行以下JSON数据操纵。

写入数据

运用数组体式格局写入JSON数据:

$user = new User;

$user->name = 'thinkphp';

$user->info = [

'email' => 'thinkphp@qq.com',

'nickname '=> '流年',

];

$user->save();

运用对象体式格局写入JSON数据

$user = new User;

$user->name = 'thinkphp';

$info = new StdClass();

$info->email = 'thinkphp@qq.com';

$info->nickname = '流年';

$user->info = $info;

$user->save();

查询数据

和Db类查询出来的效果范例差别,模子的JSON字段会自动转换成对象体式格局。

$user = User::get(1);

echo $user->name; // thinkphp

echo $user->info->email; // thinkphp@qq.com

echo $user->info->nickname; // 流年

一样也能够支撑查询JSON字段数据

$user = User::where('info->nickname','流年')->find();

echo $user->name; // thinkphp

echo $user->info->email; // thinkphp@qq.com

echo $user->info->nickname; // 流年

和Db类查询一样,假如你须要查询的JSON属性是整型范例的话,须要举行手动参数绑定。

$user = User::where('info->user_id',':user_id')

->bind(['user_id' => [10 ,\PDO::PARAM_INT]])

->find();

echo $user->name; // thinkphp

echo $user->info->email; // thinkphp@qq.com

echo $user->info->nickname; // 流年

假如你运用的是V5.1.11+版本的话,能够在模子类内里定义JSON字段的属性范例,就会自动举行响应范例的参数绑定查询。

namespace app\index\model;

use think\Model;

class User extends Model

{

// 设置json范例字段

protected $json = ['info'];

// 设置JSON字段的范例

protected $jsonType = [

'user_id'=>'int'

];

}

没有定义范例的属性默以为字符串范例,因而字符串范例的属性能够无需定义。

更新数据

更新JSON数据也是采纳对象的体式格局

$user = User::get(1);

$user->name = 'kancloud';

$user->info->email = 'kancloud@qq.com';

$user->info->nickname = 'kancloud';

$user->save();

假如你须要对JSON范例字段做更庞杂的操纵,还能够经由过程exp表达式体式格局完成。这个就守候人人去发明更多的JSON用法了。

ki4网,有大批免费的ThinkPHP入门教程,迎接人人进修!

本文转自:https://blog.thinkki4.cn/784281

以上就是ThinkPHP:JSON字段范例的运用(ORM)的细致内容,更多请关注ki4网别的相干文章!

为木唯品 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权

转载请注明原文链接:ThinkPHP:JSON字段范例的运用(ORM)_PHP开发框架教程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值