thinkphp mysql json数据类型_ThinkPHP:JSON字段类型的使用(ORM)
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属性定义即可。<?php
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字段的属性类型,就会自动进行相应类型的参数绑定查询。<?php
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用法了。
PHP中文网,有大量免费的ThinkPHP入门教程,欢迎大家学习!
本文转自:https://blog.thinkphp.cn/784281
thinkphp mysql json数据类型_ThinkPHP:JSON字段类型的使用(ORM)相关推荐
- mysql修改数据类型_MySQL修改字段类型
mysql> alter table 表名 modify column 字段名 类型.数据库中address表 city字段是varchar(30),修改类型可以用(谨慎修改类型,可能会导致原有 ...
- Oracle/MSSQL/Mysql 常用数据库的字段类型及大小
Oracle/MSSQL/Mysql 常用数据库的字段类型及大小 ORACLE的数据类型 常用的数据库字段类型如下: 字段类型 中文说明 限制条件 其它说明 CHAR 固定长度字 ...
- 【mysql】mysql 中 text,longtext,mediumtext 字段类型的意思, 以及区别
mysql 中 text,longtext,mediumtext 字段类型的意思, 以及区别 mysql 中 text,longtext,mediumtext 字段类型区别为:字节限制不同.I/O 不 ...
- Sql2000、Json、Sqlite3数据库字段类型对照表
Sql2000.Json.Sqlite3.delphiXE数据库类型对照表 一.对照表及重要说明 Sql2000 Json ...
- Mysql修改字段名、修改字段类型、删除字段
目录 1.修改字段类型.字段名.字段注释.类型长度.字段默认值 2.修改表名 3.修改表的注释 4.在指定位置插入新字段 5.删除字段 1. 修改字段类型.字段名.字段注释.类型长度.字段默认值 my ...
- 修改mysql 视图字段类型_记一次mysql视图创建时自定义字段类型不同环境不同的原因...
由于老项目使用的是hibernate,当项目启动时会去检查数据库字段类型等,发现一张视图中某个自定义字段在开发环境中类型为text,但是到了生产环境类型却为mediumtext,导致代码在生产上会有问 ...
- thinkphp mysql操作数据库_thinkPHP数据库操作
thinkPHP如果要对数据库操作,一般来说首先要做的是在配置文件中链接数据库,然后用M方法实例化一张表,然后就是对表的操作了 可以开启调试功能查看程序执行的sql语句: 1.开启调试功能(默认是已经 ...
- php mysql 时间字段_php – MySQL中各种日期/时间字段类型的优...
> TIMESTAMP存储在MySQL专有方法中(尽管它基本上只是一个由年,月,日,小时,分钟和秒组成的字符串),此外,只要插入或更改记录,TIMESTAMP类型的字段就会自动更新.显式字段值给 ...
- Oracle 20c 新特性:原生的 JSON 数据类型(Native JSON Datatype)
墨墨导读:Oracle 在 12c(12.1.0.2)版本中引入了对JSON的支持,允许将JSON存储在数据库中的varchar2或LOB(CLOB或BLOB)中.这意味着,我们可以利用无模式设计模型 ...
最新文章
- YOLOv5x6模型来了! 同样支持CPU上ONNX部署与推理
- attiny13a程序实例_ATtiny13A带A新版本
- python代码安全扫描工具
- NSIS 的 Modern UI 教程(二)
- ospf多区域配置为什么ping不通_「实战」动态路由多区域 OSPF 基本配置,一分钟了解下...
- MSF(一):MSF基础
- 微信小程序部分功能介绍和实现
- 电脑软件:推荐5款实用的效率软件,每一款都爱不释手!
- 二叉树的锯齿形层次遍历
- android 访问服务器sql_一次服务器被传webshell事件溯源
- 一次函数(正比例函数)公式的解析式与C语言代码实现
- POJ2728 最小比率生成树/0-1分数规划/二分/迭代(迭代不会)
- Win11系统虽香但不是想升就能升?这三款精品win11升级检测工具告诉您的爱机是否达标!!!
- Pr 入门教程如何使用精确的剪辑蒙版?
- 五、Ceph之RBD存储使用
- 概率论中一个有趣的问题-------双六问题
- 一个经常玩电脑的人应该知道的:电脑快捷键
- rk3288 Android 8,RK3288W Android8.1开发日志(一)
- 泰裤辣!五一烧烤倒计时,还有人没做好攻略吗?
- Go1.9 安全map用法
热门文章
- 使用yeoman搭建脚手架并发布到npm
- 【转】iPhone4清理垃圾文件的方法
- node使用npm一句命令停止某个端口号 xl_close_port
- XenApp_XenDesktop_7.6实战篇之十四:XenDesktop虚拟桌面的交付
- libSVM 参数选择
- 拼图游戏 复制粘贴一个叫lemene的人的,这个人是c++博客的用户,我不是,怕以后找不到这篇文章,所以复制粘贴了。文中最后给出了原文链接连接...
- 《裂变》作者爆料:欺世盗名者绝非唐骏一人
- 字符集GBK和UTF8的区别说明
- 内网渗透测试:隐藏通讯隧道技术(上)
- requests.exceptions.ConnectionError: (‘Connection aborted.‘, BadStatusLine(“‘‘“,))