Yii数据库增删查的操作方法是怎样,代码是什么
Admin 2022-06-30 群英技术资讯 1134 次浏览
这篇文章主要介绍“Yii数据库增删查的操作方法是怎样,代码是什么”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Yii数据库增删查的操作方法是怎样,代码是什么”文章能帮助大家解决问题。本文实例讲述了Yii框架数据库查询、增加、删除操作。分享给大家供大家参考,具体如下:
Yii 数据库查询
模型代码:
<?php
namespace app\models;
use yii\db\ActiveRecord;
class Test extends ActiveRecord{
}
控制器代码:
public function actionTest(){
//方法一
$sql = 'select * from test where id=:id';
$data = Test::findBySql($sql,array(':id'=>1))->all();
var_dump($data);//数组
//方法二
$data = Test::find()->where(['id'=>1])->all();
var_dump($data);//复杂的对象信息
// 查询条件>的使用
$data = Test::find()->where(['>','id',1])->all();
var_dump($data);//复杂的对象信息
// 查询条件 between 的使用
$data = Test::find()->where(['between','id',2,5])->all();
var_dump($data);//复杂的对象信息
// 查询条件 like 的使用
$data = Test::find()->where(['like','title','title1'])->all();
var_dump($data);//复杂的对象信息
//查询结果对象转化为数组,使用asArray
$data = Test::find()->where(['between','id',2,5])->asArray()->all();
var_dump($data);//复杂的对象信息
//批量查询,例如每次获取2条
$data = array();
foreach(Test::find()->asArray()->batch(2) as $tests){
foreach($tests as $val){
$data[] = $val;
}
}
print_r($data);
}
总结,主要注意防止sql注入的占位符的使用,各种查询条件的使用,转化数组的使用,批量查询的使用。
yii 数据库增加数据
模型代码:
<?php
namespace app\models;
use yii\db\ActiveRecord;
class Test extends ActiveRecord{
public function rules()
{
return [
['title','string','length'=>[0,10]]
];
}
}
控制器代码:
public function actionTest(){
//添加数据
$test = new Test;
$test->title = '';
$test->validate();
if ($test->hasErrors()) {
echo 'error';
} else {
$test->save();
}
}
结论:保存数据及验证数据。
yii 数据库删除数据
public function actionTest(){
//删除
//方法一
$result = Test::find()->where(['id' => 1])->all();
$result[0]->delete();
//方法二
Test::deleteAll('id>:id', array(':id' => 5));
}
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在本篇文章中小编给大家分享了关于PHP的curl函数的用法总结以及相关知识点内容,需要的读者们学习下。
Swoole是一个面向生产环境的PHP异步网络通信引擎;而Libevent是一个用C语言编写的、轻量级的开源高性能事件通知库。Swoole Socket网络开发框架,是基于php的libevent和pcntl模块的,并且只能用于Linu
这篇文章主要介绍了Laravel5.1框架路由分组用法,结合实例形式分析了laravel5.1框架路由分组基本功能与相关共享属性使用技巧,需要的朋友可以参考下
在thinkphp中,eq是一个比较标签,可以比较标签参数name和value的值,若name和value的值相等的话则输出eq标签之间的内容,语法为“<eq name="变量" value="值">内容</eq>”。
swoole中绝大部分的模块只能用于CLI命令行环境,只有同步阻塞的swoole_client可以用于php-fpm或apache环境。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008