广告
返回顶部
首页 > 资讯 > 数据库 >YII2数据库如何查询
  • 237
分享到

YII2数据库如何查询

2024-04-02 19:04:59 237人浏览 泡泡鱼
摘要

小编给大家分享一下YII2数据库如何查询,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!数据库配置。/config/db.PHP

小编给大家分享一下YII2数据库如何查询,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

数据库配置。

/config/db.PHP 进行数据库配置

实践过程中有个test库-》test表-》两条记录如下

Mysql> select * from test;
+----+--------+
| id | name |
+----+--------+
| 1 | zhuai |
| 2 | heng | 
+----+--------+
18 rows in set (0.00 sec)

sql 查询方式

yii2 提供了原始的数据库查询方式findBysql;同时, 通过占位符的方式,自动进行了基本的sql注入防御 。上码

// 最基本的查询方式
$sql = "select * from test where 1";
$res = Test::findBySql($sql)->all();
var_dump(count($res)); // res->2 
// findbysql 防止sql注入方式
$id = '1 or 1=1';
$sql = "select * from test where id = " . $id;
$res = Test::findBySql($sql)->all();
var_dump(count($res)); // res-> 2
$sql = "select * from test where id = :id";
// 定位符会自动防止sql 注入
$res = Test::findBySql($sql,array(":id"=>$id))->all();
var_dump(count($res)); // res->1

activeRecord查询方式

每个框架除了原有的sql方式,都会提供相应的封装的查询方式,yii2亦然。

创建model

yii的model基本方式如下,代码如下不赘述。

<?php
namespace app\models;
use Yii;
use yii\db\ActiveRecord;
class Test extends ActiveRecord
{
// 可无,对应表:默认类名和表名匹配,则无需此函数
public static function tableName()
{
return 'test';
}
// 可无,验证器:主要用于校验各个字段
public function rules(){
return [
['id', 'integer'],
['name', 'string', 'length' => [0, 100]],
];
}
}

使用的时候需要引入model

use app\models\Test;
增加操作
// add 操作
$test = new Test();
$test->name = 'test';
// 合法性校验
$test->validate();
if($test->hasErrors()){
echo "数据不合法";
die;
}
$test->save();

查询操作

查询操作先上官方文档

activeRecord doc

where doc

需要强调的是:yii查询提供了特别多丰富的库,例如代码中的批量查询处理等等,细节可以看文档。

// select
// id = 1
$res = Test::find()->where(['id' => 1])->all();
var_dump(count($res)); //1
// id > 0
$res = Test::find()->where(['>','id',0])->all();
var_dump(count($res)); //2
// id > =1 id <=2
$res = Test::find()->where(['between','id',1,2])->all();
var_dump(count($res)); //2
// name字段like
$res = Test::find()->where(['like', 'name', 'cuihuan'])->all();
var_dump(count($res)); //2
// 查询的使用 obj->array
$res = Test::find()->where(['between','id',1,2])->asArray()->all();
var_dump($res[0]['id']); //2
// 批量查询,对于大内存操作的批量查询
foreach (Test::find()->batch(1) as $test) {
var_dump(count($test));
}

删除操作

// delete 
// 选出来删除
$res = Test::find()->where(['id'=>1])->all();
$res[0]->delete();
// 直接删除
var_dump(Test::deleteAll('id>:id', array(':id' => 2)));

修改操作

除了代码中方式,yii2直接提供update操作。

// 活动记录修改
$res = Test::find()->where(['id'=>4])->one();
$res->name = "update";
$res->save();

关联查询操作

关联查询示例中两个表:

一个学生表(student):id ,name;

一个分数表(score):id,stu_id,score

// 相应学生的所有score
$stu = Student::find()->where(['name'=>'xiaozhuai'])->one();
var_dump($stu->id);
// 基本获取
$scores_1 = $stu->hasMany('app\model\Score',['stu_id'=>$stu->id])->asArray()->all();
$scores_2 = $stu->hasMany(Score::className(),['stu_id'=>'id'])->asArray()->all();
var_dump($scores_1);
var_dump($scores_2);

两种关联查询方式;但是,在controller进行相关操作,代码显的过于混乱,在model中封装调用

首先在student model中封装相关关联调用函数

<?php
namespace app\models;
use Yii;
use yii\db\ActiveRecord;
class Student extends ActiveRecord
{
public static function tableName()
{
return 'student';
}
// 获取分数信息
public function getScores()
{
$scores = $this->hasMany(Score::className(), ['stu_id' => 'id'])->asArray()->all();
return $scores;
}
}

之后直接调用,两种调用方式

// 函数封装之后调用
$scores = $stu->getScores();
var_dump($scores);
// 利用__get 的自动调用的方式
$scores = $stu->scores;
var_dump($scores);

以上是“YII2数据库如何查询”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: YII2数据库如何查询

本文链接: https://www.lsjlt.com/news/59972.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • YII2数据库如何查询
    小编给大家分享一下YII2数据库如何查询,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!数据库配置。/config/db.php ...
    99+
    2022-10-18
  • 查询数据(数据库)——简单查询
    目录 1.最简单的查询 (1)查询指定列 (2)查询所有列 (3)查询计算列 (4)为列起别名 (5)使用DISTINCT关键字消除重复元组 2.查询满足条件的元组 (1) 比较大小 (2) 确定范围 (3) 确定集合 (4) 字符匹配 (...
    99+
    2023-10-11
    数据库 sql mysql
  • YII2数据库CURD操作
    //1.简单查询   $admin=Admin::model()->findAll($condition,$params);   $admin=Admin::m...
    99+
    2022-10-18
  • LINQ如何查询数据库
    这篇文章给大家分享的是有关LINQ如何查询数据库的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。您可以通过LINQ来编写针对各种数据源的查询访问信息。您不必在使用SQL语法,因为LINQ提供了c#语言来处理,并提供...
    99+
    2023-06-17
  • 如何用数据库分页查询语句进行数据库查询
    这篇文章主要介绍“如何用数据库分页查询语句进行数据库查询”,在日常操作中,相信很多人在如何用数据库分页查询语句进行数据库查询问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何...
    99+
    2022-10-18
  • php如何查询数据库输出查询结果
    这篇文章主要讲解了“php如何查询数据库输出查询结果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php如何查询数据库输出查询结果”吧!连接数据库在开始查询数据库之前,需要先连接到数据库。在...
    99+
    2023-07-05
  • PHP中如何查询数据库
    小编给大家分享一下PHP中如何查询数据库,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!查询方法应该如何实现:我们根据以前所讲的原...
    99+
    2022-10-18
  • 如何查询mysql的数据库
    本篇内容介绍了“如何查询mysql的数据库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • python数据库查询
    import pymysqlccon=pymysql.connect( host=‘127.0.0.1‘, user=‘root‘, password=‘password‘, port=3306, db=‘sy...
    99+
    2019-05-27
    python数据库查询 数据库入门 数据库基础教程
  • java如何实现数据库查询
    Java可以使用JDBC(Java Database Connectivity)来实现数据库查询。具体步骤如下:1. 加载数据库驱动...
    99+
    2023-09-22
    java 数据库
  • mysql如何查询数据库容量
    本篇内容介绍了“mysql如何查询数据库容量”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2023-04-03
    mysql 数据库
  • 分库数据如何查询统计
    分库后的计算不能直接使用SQL;异构库 SQL 函数不尽相同;JAVA 硬编码实施难度大;即使借助透明网关访问远程数据库,分库性能优化也是头疼问题。 一般常规办法: 方法1:java硬编码 简单的跨库count运算,Java部分代码大...
    99+
    2017-06-06
    分库数据如何查询统计
  • mysql如何查询数据库版本
    这篇文章主要讲解了“mysql如何查询数据库版本”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql如何查询数据库版本”吧! ...
    99+
    2022-10-19
  • mysql如何查询所有数据库
    这篇文章主要介绍了mysql如何查询所有数据库,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 mysql查询所有...
    99+
    2022-10-19
  • thinkphp如何查询重复数据库
    这篇文章主要介绍了thinkphp如何查询重复数据库的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇thinkphp如何查询重复数据库文章都会有所收获,下面我们一起来看看吧。thinkphp查询重复数据库的方法:...
    99+
    2023-07-04
  • Yii2中mssql和sql server数据库如何使用
    本篇文章给大家分享的是有关Yii2中mssql和sql server数据库如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。  1.首先找...
    99+
    2022-10-18
  • 如何查询数据库数据量的大小
    这篇文章主要介绍如何查询数据库数据量的大小,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!查询一下数据库的数据量的大小,自己做了个脚本:select sum(zon...
    99+
    2022-10-18
  • php 查询数据库  数组
    在PHP开发中,数据库查询是必不可少的操作之一。 作为一种高效的动态语言,PHP提供了许多内置函数来帮助我们进行数据库操作。其中最重要的是PHP的数组。数组是PHP语言中最为重要和常用的结构之一。它们可以用于存储和操作数据,也可以将多个数据...
    99+
    2023-05-19
  • 数据库查询语句
    插入数据    INSERT 语法结构        INSERT [INTO] &l...
    99+
    2022-10-18
  • nodejs查询数据库防
    止SQL注入的方法随着互联网的迅猛发展,应用程序的数据交互越来越频繁,数据库的使用也变得越来越重要,而SQL注入攻击也愈发猖獗。SQL注入是指黑客将恶意代码注入到应用程序的SQL语句中,当数据传入到数据库时,恶意代码就能够执行,从而造成数据...
    99+
    2023-05-16
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作