yii学习笔记(6),连接数据库,创建活动记录类
创建数据库用于测试

配置数据库连接
打开yii的配置文件目录下的数据库配置文件config/db.php
<?php return [
'class' => 'yii\db\Connection',
'dsn' => 'mysql:host=数据库地址;dbname=数据库名称',
'username' => '账号',
'password' => '密码',
'charset' => 'utf8',
];
填写相关配置,注意:需要开启php的pdo扩展
创建活动记录类
活动记录类和数据库的表关联,用以访问和操作数据库中的数据
一般活动记录类名对应相关联的表名,如果不同在创建活动记录类的时候重写tableName()方法声明表名
活动记录被称为“模型”
在models目录创建模型文件
<?php
namespace app\models; use yii\db\ActiveRecord; class Article extends ActiveRecord{ }
类名和模型文件名称相同
需要定义明命空间为namespace app\models;
继承yii\db\ActiveRecord;
调用模型
在控制器中调用模型获取数据
<?php
namespace app\controllers; use yii;
use yii\web\Controller;
use app\models\Article; class HomeController extends Controller{ public $layout = "home"; function actionIndex(){ $request = Yii::$app->request;
$id = $request->get("id"); // 定义sql语句,:id是占位符,防止sql注入
$sql = "select * from article where id = :id";
// 调用查询方法通过sql语句获取数据,第二个参数是给占位符替换内容
$r = Article::findBySql($sql,[":id"=>$id])->all();
dd($r);
// 加载视图
return $this->render("index",compact("host","text"));
}
}
结果如下:

yii提供了防止sql注入的方法
在定义sql语句时用户输入内容采用了占位符
在调用查询方法时将数据和占位符匹配绑定和其他处理,并不是直接拼接sql语句
基本的查询操作
// 获取全部数据
$data = Article::find()->all();
// 获取id=5的记录
$data = Article::find()->where(["id"=>5])->all();
// 获取id>5的记录
$data = Article::find()->where([">","id",5])->all();
// 获取id>2,id<5之间的记录
$data = Article::find()->where(["between","id",2,5])->all();
// 模糊查询like
$data = Article::find()->where(["like","title","Google"],[">","id",3])->all();
// 获取一条记录,默认条件是id
$data = Article::findOne(5);
// 获取多天记录
$data = Article::findAll([2,3,5]);
详细的可以查看中文文档http://www.yiichina.com/doc/guide/2.0/db-active-record
yii学习笔记(6),连接数据库,创建活动记录类的更多相关文章
- yii学习笔记(6),数据库操作(增删改)
数据库增删改操作通过活动记录实例来完成 插入记录 /* ----------添加记录---------- */ // 创建活动记录对象 $article = new Article(); $artic ...
- InterSystems Ensemble学习笔记(二) Ensemble创建镜像, 实现自动故障转移
系列目录 InterSystems Ensemble学习笔记(一) Ensemble介绍及安装InterSystems Ensemble学习笔记(二) Ensemble创建镜像, 实现自动故障转移 一 ...
- 【opencv学习笔记八】创建TrackBar轨迹条
createTrackbar这个函数我们以后会经常用到,它创建一个可以调整数值的轨迹条,并将轨迹条附加到指定的窗口上,使用起来很方便.首先大家要记住,它往往会和一个回调函数配合起来使用.先看下他的函数 ...
- qml学习笔记(二):可视化元素基类Item详解(上半场anchors等等)
原博主博客地址:http://blog.csdn.net/qq21497936本文章博客地址:http://blog.csdn.net/qq21497936/article/details/78516 ...
- C#可扩展编程之MEF学习笔记(三):导出类的方法和属性
前面说完了导入和导出的几种方法,如果大家细心的话会注意到前面我们导出的都是类,那么方法和属性能不能导出呢???答案是肯定的,下面就来说下MEF是如何导出方法和属性的. 还是前面的代码,第二篇中已经提供 ...
- Android学习笔记(六)——活动的启动模式
//此系列博文是<第一行Android代码>的学习笔记,如有错漏,欢迎指正! 活动的启动模式共有四种: standard.singleTop.singleTask 和 singleInst ...
- Android学习笔记(五)——活动的生命周期
//此系列博文是<第一行Android代码>的学习笔记,如有错漏,欢迎指正! 为了能写出流畅连贯的程序,我们需要了解一下活动的生命周期. 一.返回栈 Android 中的活动是可以层叠的. ...
- yii学习笔记(四)
return $this->goBack(); // 先看看Yii::$app->user->returnUrl是否已经设置, returnUrl没有设置且goBack()中的参数也 ...
- SharpGL学习笔记(十一) 光源创建的综合例子:光源参数可调节的测试场景
灯光的测试例子:光源参数可以调节的测试场景 先看一下测试场景和效果. 场景中可以切换视图, 以方便观察三维体和灯光的位置.环境光,漫射光,镜面反射光都可以在四种颜色间切换. 灯光位置和摄像机位置(Lo ...
随机推荐
- js 时间格式化 (兼容safari)
js 时间格式化,兼容IE8和safari浏览器. function formatDate(date, fmt, near, type) { var dateStr = date; if (!date ...
- lodash常用函数 - Array、Collection
lodash常用函数 - Array.Collection lodash版本 v3.10.1 1.Array.Collection pull 移除数组中满足条件的元素 var array = [1, ...
- 使用intellij idea搭建MAVEN+SSM(Spring+SpringMVC+MyBatis)框架
基本概念 使用SSM(Spring,SpringMVC和Mybatis) 1.1.Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod ...
- C#清空回收站
曾经用过bat处理回收站,但是效果很不理想(应该是我水平不够吧),后来发现C#可以直接调用系统dll,非常简单.下面是具体函数: class ClearRecycle { [DllImport(&qu ...
- win 8系统:System.IO.FileNotFoundException: 未能加载文件或程序集“CefSharp.Core.dll”或它的某一个依赖项。找不到指定的模块
最近用CefSharp做了一个chrome核心的浏览器. 在win 7.win 10系统上都正常运行,但是在win 8系统上报错了. win 8系统:System.IO.FileNotFoundExc ...
- C#中的多线程 - 并行编程 z
原文:http://www.albahari.com/threading/part5.aspx 专题:C#中的多线程 1并行编程Permalink 在这一部分,我们讨论 Framework 4.0 加 ...
- js 更改对象中的属性名
const json = JSON.parse(JSON.stringify(options).replace(/name/g,"label")); 注: 1.options是需要 ...
- 大数据平台搭建:Hadoop
To construct big data distributed platform based on Hadoop is a common method. Hadoop comes fron Goo ...
- Topic model的变种及其应用[1]
转: http://www.blogbus.com/krischow-logs/65749376.html LDA 着实 带领着 Topic model 火了一把. 但是其实我们华人世界内,也不乏 ...
- ADF系列-1.EO的各个属性初探
ADF中的EO可以看做关系型数据库中表的java展现形式. 1.Type 此处的Type是java的类型,而需要映射的是数据库的类型,两者之间存在一些差异,各个映射关系如下: 数据库列类型 BC 属性 ...