创建数据库用于测试

配置数据库连接

打开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),连接数据库,创建活动记录类的更多相关文章

  1. yii学习笔记(6),数据库操作(增删改)

    数据库增删改操作通过活动记录实例来完成 插入记录 /* ----------添加记录---------- */ // 创建活动记录对象 $article = new Article(); $artic ...

  2. InterSystems Ensemble学习笔记(二) Ensemble创建镜像, 实现自动故障转移

    系列目录 InterSystems Ensemble学习笔记(一) Ensemble介绍及安装InterSystems Ensemble学习笔记(二) Ensemble创建镜像, 实现自动故障转移 一 ...

  3. 【opencv学习笔记八】创建TrackBar轨迹条

    createTrackbar这个函数我们以后会经常用到,它创建一个可以调整数值的轨迹条,并将轨迹条附加到指定的窗口上,使用起来很方便.首先大家要记住,它往往会和一个回调函数配合起来使用.先看下他的函数 ...

  4. qml学习笔记(二):可视化元素基类Item详解(上半场anchors等等)

    原博主博客地址:http://blog.csdn.net/qq21497936本文章博客地址:http://blog.csdn.net/qq21497936/article/details/78516 ...

  5. C#可扩展编程之MEF学习笔记(三):导出类的方法和属性

    前面说完了导入和导出的几种方法,如果大家细心的话会注意到前面我们导出的都是类,那么方法和属性能不能导出呢???答案是肯定的,下面就来说下MEF是如何导出方法和属性的. 还是前面的代码,第二篇中已经提供 ...

  6. Android学习笔记(六)——活动的启动模式

    //此系列博文是<第一行Android代码>的学习笔记,如有错漏,欢迎指正! 活动的启动模式共有四种: standard.singleTop.singleTask 和 singleInst ...

  7. Android学习笔记(五)——活动的生命周期

    //此系列博文是<第一行Android代码>的学习笔记,如有错漏,欢迎指正! 为了能写出流畅连贯的程序,我们需要了解一下活动的生命周期. 一.返回栈 Android 中的活动是可以层叠的. ...

  8. yii学习笔记(四)

    return $this->goBack(); // 先看看Yii::$app->user->returnUrl是否已经设置, returnUrl没有设置且goBack()中的参数也 ...

  9. SharpGL学习笔记(十一) 光源创建的综合例子:光源参数可调节的测试场景

    灯光的测试例子:光源参数可以调节的测试场景 先看一下测试场景和效果. 场景中可以切换视图, 以方便观察三维体和灯光的位置.环境光,漫射光,镜面反射光都可以在四种颜色间切换. 灯光位置和摄像机位置(Lo ...

随机推荐

  1. div浮层,滚动条移动,保持位置不变的4种方法

    div浮层,滚动条移动,保持位置不变的4种方法 div在顶部不变.滚动条滚动,div还是在顶部! 直接上传源码 了: 方法一: <!DOCTYPE html PUBLIC "-//W3 ...

  2. 爬虫入门之Scrapy框架实战(新浪百科豆瓣)(十二)

    一 新浪新闻爬取 1 爬取新浪新闻(全站爬取) 项目搭建与开启 scrapy startproject sina cd sina scrapy genspider mysina http://roll ...

  3. laravel中delete()方法和destroy()方法的区别

    delete()方法是实例方法,需要查询到相应的数据并通过模型实例调用 destroy()方法可以直接调用,通过索引删除记录 举个栗子: /*delete()方法删除*/ //先查找记录 $blog ...

  4. Spring-aop实现切面的四种方式 (2)

    AOP实现方式一 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http ...

  5. easyui学习笔记3—在展开行内的增删改操作

    这一篇介绍在一个展开行内进行的增删操作,如果一行很长有很多的数据,在一个展开行内进行编辑将更加方便. 1.先看引用的资源 <link rel="stylesheet" hre ...

  6. 360网站卫士SQL注入绕过案例一个

    不要以为用了360就可以高枕无忧,直接在netcraft的site_report中找到源站服务器IP,直接SQL脱裤,甚至可获取服务器权限. 存在漏洞的网站: 手工测试存在注入点: 但是网站有360保 ...

  7. 初识java——Java程序的历史、开发和运行

    上了一节Java试听课,整理出如下笔记.     Java最新版本下载 http://www.oracle.com/technetwork/java/javase/downloads/index.ht ...

  8. Maven项目打包jar依赖外部jar

    有时候我们想要做一些java 的小程序,需要把打包成jar,单独执行,做一个maven项目,maven非常方便,有自动打包成jar的插件,但是有时候我们的项目可能会依赖其他的jar包,所以非常麻烦. ...

  9. node express 跨域问题

    express = require('express'); var app = express(); //设置跨域访问 app.all('*', function(req, res, next) { ...

  10. 20165214 2018-2019-2 《网络对抗技术》Exp6 信息搜集与漏洞扫描 Week9

    <网络对抗技术>Exp6 信息搜集与漏洞扫描 Week9 一.实验目标与内容 1.实践目标 掌握信息搜集的最基础技能与常用工具的使用方法. 2.实践内容 (1)各种搜索技巧的应用 使用搜索 ...