Yii2 学习心得

<?php
/**
* Yii框架的数据库查询是基于pdo来执行的
* main-local 这种凡是带local的是为了避免开发冲突设计的,可以在本地修改配置,但是不要提交就可以
*/

//sql查询
Yii::$app->db->createCommand(‘select * from post‘)->queryAll();
Yii::$app->db->createCommand(‘select * from post‘)->queryOne();

//根据id查询sql
Yii::$app->db->createCommand(‘select * from post where id = :id and status = :status‘)
->bindValue(‘:id‘,$_GET[‘id‘])
->bindValue(‘:status‘,1)
->queryAll();

//使用ActiveRecord查询
Post::find()->where([‘id‘=>1])->all();
Post::find()->where([‘id‘=>1])->one();

//设置查询条件
$posts = Post::find()->where([‘AND‘,[‘status‘=>2],[‘author_id‘=>1],[‘like‘,‘title‘,‘标题内容‘]])->orderby(‘id‘)->all();

findBySql();//这也是一种查询方法

//或者

Post::findOne(1);
Post::findAll([‘id‘=>1,]);

//输出id
$model = Post::findOne(1);
echo $model->id;

//curl其中save可以代替insert和update
//添加
$post = new Post();
$post->id = 1;
$post->status = 2;
$post->save();//等同于insert

//修改
$post = Post::findOne($id);
$post->status = 1;
$post->save();//等同于修改

//删除
$post = Post::findOne($id);
$post->delete();

//DetailView用于显示一条记录的数据
<?= DetailView::widget([
‘model‘ => $model,
‘attributes‘ => [
‘id‘,
‘title‘,
‘content:ntext‘,
‘tags:ntext‘,
‘status‘,
‘create_time:datetime‘,
‘update_time:datetime‘,
‘author_id‘,
],
]),

//。。。。。。。还可以添加属性控制表单样式
‘template‘=>‘<tr><th style="width: 120px;">{label}</th><td>{value}</td></tr>‘,//设置label的样式
‘options‘=>[‘class‘=>‘table table-striped table-bodered detail-view‘],//设置整个表格的属性样式
?>

像上面的这种ntext、datetime这种的都是展示的格式
ntext会把网页的标签都展示出来
datetime展示的yii的时间形式Sep 23, 2015 4:51:54 PM

变化时间那么就用这种样子的
[
‘attribute‘=>‘update_time‘,
‘value‘=>date(‘Y-m-d H:i:s‘,$model->update_time),
],

//ListView和GirdView可以对数据进行分页、排序和过滤
hasOne用于多对一、一对一的情况
hasMany用于一对多的情况

例如:我的model层代码有
public function getStatus0()
{
return $this->hasOne(Poststatus::className(), [‘id‘ => ‘status‘]);
}

那么我在展示的时候就可以写成:
[
‘label‘=>‘状态‘,
‘value‘=>$model->status0->name,
],

或者

public function getAuthor()
{
return $this->hasOne(Adminuser::className(), [‘id‘ => ‘author_id‘]);
}

展示也可以写成
[
‘attribute‘=>‘author_id‘,
‘value‘=>$model->author->nickname,
]

//别名-用来替代网址或者一些路径之类的(必须用@开头)
Yii::setAlias(‘@foo‘,‘/path/to/foo‘);//文件路径别名
Yii::setAlias(‘@foo‘,‘http://www.baidu.com‘);//URL别名

别名的使用

$cache = new FileCache([
‘cachePath‘=>‘@runtime/cache‘,
]);

//下拉框示例
<?= $form->field($model, ‘status‘)
->dropDownList([‘1‘=>‘草稿‘,‘2‘=>‘已发布‘],[‘prompt‘=>‘请选择状态‘]);
?>

那么和数据库交互以后的下拉框可以这样写
<?php
$poststatus = Poststatus::find()->all();//model也是要注意引用
$allStatus = ArrayHelper::map($poststatus,‘id‘,‘name‘);//类文件需要引用以后才可以这样简写ArrayHelper
?>
<?= $form->field($model, ‘status‘)
->dropDownList($allStatus,
[‘prompt‘=>‘请选择状态‘]);?>

又或者这样写:
<?php
$psArray = Yii::$app->db->createCommand(‘select id,name from poststatus‘)->queryAll();
$allStatus = ArrayHelper::map($psArray,‘id‘,‘name‘);
?>

又或者用query-buider
<?php
$allStatus = (new \yii\db\query())
->select([‘name‘,‘id‘])
->from(‘poststatus‘)
->indexBy(‘id‘)
->column();
?>

或者
<?php
$allStatus = Poststatus::find()
->select([‘name‘,‘id‘])
->orderBy(‘position‘)
->indexBy(‘id‘)
->column();
?>

//from查询(支持将查询出来的结果当成一张表再查询)
$subQuery = (new \yii\db\Query())->select(‘id‘)->from(‘user‘)->where(‘status=1‘);
$query->from([‘u‘=>$subQuery]);

//limit的用法
$query->limit(10)->offset(20); 表示从第20条开始取数,取10条记录

关于查询的一些语法可以参考http://www.yiichina.com/doc/guide/2.0/db-query-builder

图片总结:

时间: 2024-12-21 05:49:50

Yii2 学习心得的相关文章

Linux系统理解以及Linux系统学习心得

原创作品转载请注明出处  <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 作者:严哲璟 说一下我对Linux系统的理解 1.加载Linux内核准备:在加载基本输入输出模块(BIOS)之后,从磁盘的引导扇区读入操作系统的代码文件块到内存中,之后开始整个系统的初始化. 2.main.c的start_kernel函数是整个操作系统的入口,这也与Linux是基于C语言的特性相符,start_kernel具体做的动作很多

我的MYSQL学习心得(八)

我的MYSQL学习心得(八) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYSQL学习心得(五) 我的MYSQL学习心得(六) 我的MYSQL学习心得(七) 这一篇<我的MYSQL学习心得(七)>将会讲解MYSQL的插入.更新和删除语句 同样的,只会讲解跟SQLSERVER不同的地方 插入 将多行查询结果插入到表中 语法 INSERT INTO table_name1(column_list1) SELECT (

我的MYSQL学习心得(一)

我的MYSQL学习心得(一) 使用MYSQL有一段时间了,由于公司使用SQLSERVER和MYSQL,而且服务器数量和数据库数量都比较多 管理起来比较吃力,在学习MYSQL期间我一直跟SQLSERVER进行对比 第一期主要是学习MYSQL的基本语法,陆续还有第二.第三.第四期,大家敬请期待o(∩_∩)o 语法的差异 我这里主要说语法的不同 1.默认约束 区别:mysql里面DEFAULT关键字后面是不用加括号的 --sqlserver CREATE TABLE emp ( id INT DEFA

在马哥linux运维学院学习心得

题目:在马哥linux运维学院学习心得 姓名:谭龙 班级:M18 学号:26 时间:2016-02-29--2016-06-02(正常毕业时间预计在7月中上旬)   正文: 个人基本情况: 我是一名在校的即将毕业的大四学生,毕业时间为2016.7.专业为矿物加工工程专业,纯正的四川-广安人(邓小平故居就在那).因找不到工作,加上自己也不知道干什么,在堂弟的推荐下,来参加了马哥linux运维学院的学习:怀揣着一颗对计算机懵懂的心,开始涉足从未接触过了linux. 个人收获与心理变化: 在一开始接触

第一篇大数据学习心得

之前未习惯发布学习心德博文,后续会采用这种方式发布学习心得,希望能够很好的督促自己. 计划会按scala,Hadoop,Spark的顺序去学习. 刚学scala的时候,眼前一亮,这语法跟python,java很像啊,刚好两者很熟悉,偷笑,后面果然学的得心应手.今天就不发表具体的技术内容.反正王学林老师的视屏讲解很好,声音非常富有感染力,想开小差都比较难,呵呵,话语精炼,个人较喜欢的风格,这里说下这段时间学习scala的小心得?,视频学完一章紧接着进行敲代码,调试,最后记笔记,对,记笔记,不一定是

spring核心知识(学习心得)

直接进入主题,主要分为两大部分:框架学习心得和spring框架的核心知识. 学习心得 1.学习框架的时候,一定要弄清楚的几个问题: a. 这是一个什么框架 轻量级还是重量级, 侵入式还是非侵入式,是解决单个问题还是整体的解决方案. b. 框架的设计理念是什么(为了解决什么问题而出现) c. 框架的优缺点 d. 框架的架构是怎样的 e. 框架的核心是什么 f. 框架能实现哪些功能 在学习一个框架的时候如果都不知道它能够提供哪些功能,就更加不用谈功能实现和充分利用框架了 2. 在学习多个框架以后,如

C++用法的学习心得

c++这门课,在我刚进入大学的就已经开始接触了.因为自己的专业就是计算机科学,因此c++嘛,对于我来说还是比较重要的.不同于其他专业,一开始我接触就是c++了,跳过了c语言一类的课.就我自己认为,c++这课学起来还是很有难度的.大一上课的时候,老师就说过这课在生活中的应用很广泛.处于初学者的我,开始给我的感觉就是很是乏味枯燥,提不起兴趣.不过仔细想想自己的专业就是和它有关,就算将来自己不从事这个行业,还是很有学习它的必要.因为多一门技术总归是不会吃亏的. 作为男生嘛,自己没有少玩游戏.很多人玩游

Android学习心得(16) --- Dex文件结构实例解析(2)

我在博客上发表一些我的Android学习心得,希望对大家能有帮助. 这一篇我们讲述一下通过一个实例来分析dex文件结构和组成. 参考Leb128数据类型 Android学习心得(5) --- dex数据类型LEB128 参考实例分析学习理解dex文件结构Android学习心得(15) --- Dex文件结构解析(1) 参考baksmali工具使用Android学习心得(4) --- MAC下smali文件编写与运行 1.编译 我们通过一个例子来分析dex文件的构成 创建一个Hello.java文

5月YII2学习总结

5月份YII2学习任务基本上告一段落了,总体感觉只是简单学习了YII2,可以进行基本的应用开发,文档没有全部看完,自己简单做了一个QA问答系统进行练手. QA问答系统功能: 1.登陆.注册.收藏.关注 2.问答 3.文章 4.标签 5.评论 6.其他小功能 一.QA问答系统使用了的特性 模块modules:后台采用模块开发 Url管理:部分a标签使用了url管理,因为时间有限,很多地方是直接硬编码 ActiveRecord的运用:开发QA系统,使用这个就能完成所有数据交互功能了,比如多表关联ge