Yii 框架使用数据库(databases)的方法示例


Posted in PHP onMay 19, 2020

本文实例讲述了Yii 框架使用数据库(databases)的方法。分享给大家供大家参考,具体如下:

配置数据库连接

 

开始之前,请确保你已经安装了 PHP PDO 扩展和你所使用的数据库的 PDO 驱动(例如 MySQL 的 pdo_mysql)。 对于使用关系型数据库来讲,这是基本要求。

驱动和扩展安装可用后,打开 config/db.php 修改里面的配置参数对应你的数据库配置。 该文件默认包含这些内容:

<?php
 
return [
  'class' => 'yii\db\Connection',
  'dsn' => 'mysql:host=localhost;dbname=yii2basic',
  'username' => 'root',
  'password' => '',
  'charset' => 'utf8',
];

config/db.php 是一个典型的基于文件的配置工具。 这个文件配置了数据库连接 yii\db\Connection 的创建和初始化参数, 应用的 SQL 查询正是基于这个数据库。

上面配置的数据库连接可以在应用中通过 Yii::$app->db 表达式访问。

信息: config/db.php 将被包含在应用配置文件 config/web.php 中, 后者指定了整个应用如何初始化。 请参考配置章节了解更多信息。

如果想要使用 Yii 没有捆绑支持的数据库,你可以查看以下插件:

  • Informix
  • IBM DB2
  • Firebird

创建活动记录

 

创建一个继承自活动记录类的类 Country, 把它放在 models/Country.php 文件,去代表和读取 country 表的数据。

<?php
 
namespace app\models;
 
use yii\db\ActiveRecord;
 
class Country extends ActiveRecord
{
}

这个 Country 类继承自 yii\db\ActiveRecord。你不用在里面写任何代码。 只需要像现在这样,Yii 就能根据类名去猜测对应的数据表名。

信息: 如果类名和数据表名不能直接对应, 可以覆写 tableName() 方法去显式指定相关表名。

使用 Country 类可以很容易地操作 country 表数据,就像这段代码:

 

use app\models\Country;


// 获取 country 表的所有行并以 name 排序
$countries = Country::find()->orderBy('name')->all();

 
// 获取主键为 “US” 的行
$country = Country::findOne('US');

 
// 输出 “United States”
echo $country->name;

// 修改 name 为 “U.S.A.” 并在数据库中保存更改 
$country->name = 'U.S.A.'; 
$country->save();

 

信息: 活动记录是面向对象、功能强大的访问和操作数据库数据的方式。你可以在活动记录章节了解更多信息。 除此之外你还可以使用另一种更原生的被称做数据访问对象的方法操作数据库数据。

创建动作

 

为了向最终用户显示国家数据,你需要创建一个操作。相比之前小节掌握的在 site 控制器中创建操作, 在这里为所有和国家有关的数据新建一个控制器更加合理。 新控制器名为 CountryController,并在其中创建一个 index 操作, 如下:

<?php
 
namespace app\controllers;
 
use yii\web\Controller;
use yii\data\Pagination;
use app\models\Country;
 
class CountryController extends Controller
{
  public function actionIndex()
  {
    $query = Country::find();
 
    $pagination = new Pagination([
      'defaultPageSize' => 5,
      'totalCount' => $query-&gt;count(),
    ]);
 
    $countries = $query->orderBy('name')
      ->offset($pagination->offset)
      ->limit($pagination->limit)
      ->all();
 
    return $this->render('index', [
      'countries' => $countries,
      'pagination' => $pagination,
    ]);
  }
}

把上面的代码保存在 controllers/CountryController.php 文件中。

index 操作调用了活动记录 Country::find() 方法,去生成查询语句并从 country 表中取回所有数据。 为了限定每个请求所返回的国家数量,查询在 yii\data\Pagination 对象的帮助下进行分页。 Pagination 对象的使命主要有两点:

  • 为 SQL 查询语句设置 offsetlimit 从句, 确保每个请求只需返回一页数据(本例中每页是 5 行)。
  • 在视图中显示一个由页码列表组成的分页器, 这点将在后面的段落中解释。

在代码末尾,index 操作渲染一个名为 index 的视图, 并传递国家数据和分页信息进去。

创建视图

 

views 目录下先创建一个名为 country 的子目录。 这个目录存储所有由 country 控制器渲染的视图。在 views/country 目录下 创建一个名为 index.php 的视图文件,内容如下:

<?php
use yii\helpers\Html;
use yii\widgets\LinkPager;
?>

Countries

<ul><?php foreach ($countries as $country): ?>
	<li><?=Html::encode("{$country->name} ({$country->code})")?>: <?=$country->population?></li>
	<?php endforeach; ?>
</ul>

<p><?=LinkPager::widget(['pagination' =>$pagination])?></p>

这个视图包含两部分用以显示国家数据。第一部分遍历国家数据并以无序 HTML 列表渲染出来。 第二部分使用 yii\widgets\LinkPager 去渲染从操作中传来的分页信息。 小部件 LinkPager 显示一个分页按钮的列表。 点击任何一个按钮都会跳转到对应的分页。

试运行

 

浏览器访问下面的 URL 看看能否工作:

http://hostname/index.php?r=country/index

 Yii 框架使用数据库(databases)的方法示例

首先你会看到显示着五个国家的列表页面。在国家下面,你还会看到一个包含四个按钮的分页器。 如果你点击按钮 “2”,将会跳转到显示另外五个国家的页面, 也就是第二页记录。如果观察仔细点你还会看到浏览器的 URL 变成了:

http://hostname/index.php?r=country/index&page=2

在这个场景里,Pagination 提供了为数据结果集分页的所有功能:

  • 首先 Pagination 把 SELECT 的子查询 LIMIT 5 OFFSET 0 数据表示成第一页。 因此开头的五条数据会被取出并显示。
  • 然后小部件 LinkPager 使用 Pagination::createUrl() 方法生成的 URL 去渲染翻页按钮。 URL 中包含必要的参数 page 才能查询不同的页面编号。
  • 如果你点击按钮 “2”,将会发起一个路由为 country/index 的新请求。 Pagination 接收到 URL 中 的 page 参数把当前的页码设为 2。 新的数据库请求将会以 LIMIT 5 OFFSET 5 查询并显示

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

PHP 相关文章推荐
Apache, PHP在Windows 9x/NT下的安装与配置 (二)
Oct 09 PHP
php中定义网站根目录的常用方法
Aug 08 PHP
php whois查询API制作方法
Jun 23 PHP
PHP版国家代码、缩写查询函数代码
Aug 14 PHP
php时间戳转换的示例
Mar 31 PHP
ThinkPHP跳转页success及error模板实例教程
Jul 17 PHP
php随机获取金山词霸每日一句的方法
Jul 09 PHP
php set_include_path函数设置 include_path 配置选项
Oct 30 PHP
PHP FileSystem 文件系统常用api整理总结
Jul 12 PHP
在thinkphp5.0路径中实现去除index.php的方式
Oct 16 PHP
ThinkPHP3.1.2 使用cli命令行模式运行的方法
Apr 14 PHP
PHP7 windows支持
Mar 09 PHP
PHP7生产环境队列Beanstalkd用法详解
May 19 #PHP
PHP项目多语言配置平台实现过程解析
May 18 #PHP
Yii 框架使用Forms操作详解
May 18 #PHP
thinkphp 框架数据库切换实现方法分析
May 18 #PHP
PHP接口类(interface)的定义、特点和应用示例
May 18 #PHP
php + ajax 实现的写入数据库操作简单示例
May 16 #PHP
PHP date_default_timezone_set()设置时区操作实例分析
May 16 #PHP
You might like
php调用淘宝开放API实现根据卖家昵称获取卖家店铺ID的方法
2015/07/29 PHP
PHP实现微信公众号验证Token的示例代码
2019/12/16 PHP
Javascript 复制数组实现代码
2009/11/26 Javascript
对javascript的一点点认识总结《javascript高级程序设计》读书笔记
2011/11/30 Javascript
ubuntu下安装nodejs以及升级的办法
2015/05/08 NodeJs
jQuery实现指定内容滚动同时左侧或其它地方不滚动的方法
2015/08/08 Javascript
在React框架中实现一些AngularJS中ng指令的例子
2016/03/06 Javascript
JS 日期与时间戮相互转化的简单实例
2016/06/22 Javascript
jQGrid动态填充select下拉框的选项值(动态填充)
2016/11/28 Javascript
js通过keyCode值判断单击键盘上某个键,然后触发指定的事件方法
2017/02/19 Javascript
如何给ss bash 写一个 WEB 端查看流量的页面
2017/03/23 Javascript
jQuery插件FusionCharts绘制的2D双面积图效果示例【附demo源码】
2017/04/11 jQuery
jQuery使用ajax_动力节点Java学院整理
2017/07/05 jQuery
vue解决弹出蒙层滑动穿透问题的方法
2018/09/22 Javascript
详解vue2.0模拟后台json数据
2019/05/16 Javascript
15 分钟掌握vue-next响应式原理
2019/10/13 Javascript
vue props对象validator自定义函数实例
2019/11/13 Javascript
JavaScript实现滑块验证解锁
2021/01/07 Javascript
Python中函数的参数传递与可变长参数介绍
2015/06/30 Python
用ReactJS和Python的Flask框架编写留言板的代码示例
2015/12/19 Python
python中os模块详解
2016/10/14 Python
go和python变量赋值遇到的一个问题
2017/08/31 Python
Python 正则表达式匹配字符串中的http链接方法
2018/12/25 Python
nohup后台启动Python脚本,log不刷新的解决方法
2019/01/14 Python
举例讲解Python常用模块
2019/03/08 Python
Python3.4解释器用法简单示例
2019/03/22 Python
python中setuptools的作用是什么
2020/06/19 Python
HTML5 video视频字幕的使用和制作方法
2018/05/03 HTML / CSS
德国宠物用品、宠物食品及水族馆网上商店:ZooRoyal
2017/07/09 全球购物
adidas官方旗舰店:德国运动用品制造商
2017/11/25 全球购物
美国综合购物商城:UnbeatableSale.com
2018/11/28 全球购物
八荣八耻的活动方案
2014/08/16 职场文书
党员“四风”问题批评与自我批评思想汇报
2014/10/06 职场文书
《狼王梦》读后感:可怜天下父母心
2019/11/01 职场文书
基于python制作简易版学生信息管理系统
2021/04/20 Python
Python基础之赋值,浅拷贝,深拷贝的区别
2021/04/30 Python