Yii2增删改查
Controller

<?php
namespace frontend\controllers;
use frontend\models\User;
use yii\data\Pagination;
class UserController extends \yii\web\Controller
{
//添加的表单页面展示
public function actionIndex()
{
$model = new User();
return $this->render('index',['model'=>$model]);
}
//实现入库
public function actionCreate(){
$model = new User();
$model->status = 1;
$model->create_time = time();
if($model->load(\Yii::$app->request->post()) && $model->validate()){
//密码加密
$model->pwd = $model->setPassword(\Yii::$app->request->post('User[pwd]'));
if($model->save()){
// return '保存成功';
return $this->redirect(['user/lists']);
}else{
// \Yii::$app->getSession()->setFlash('error', '保存失败');
return '保存失败';
}
}else{
return 2;
}
}
//实现列表展示
public function actionLists(){
//创建一个DB来获取所有的用户
$query = User::find();
//得到用户的总数
$count = $query->count();
// 使用总数来创建一个分页对象
$pagination = new Pagination(['totalCount' => $count,'pageSize' => '2']);
//实现分页数据
$users = $query->offset($pagination->offset)
->limit($pagination->limit)
->all();
return $this->render('lists',['data'=>$users,'pagination' => $pagination]);
}
//根据id查询当个信息
public function actionDefault(){
$id = \Yii::$app->request->get("id");
$data = User::findOne($id);
return $this->render('default',['data'=>$data]);
}
//实现根据id进行修改
public function actionUpd(){
//接收参数
$id = \Yii::$app->request->post("id");
$model = User::findOne($id);
if($model->load(\Yii::$app->request->post()) && $model->save()){
return $this->redirect(['user/lists']);
}else{
return '修改失败';
}
}
//实现删除
public function actionDel(){
$id = \Yii::$app->request->get("id");
$model = User::findOne($id);
if($model->delete()){
$this->redirect(['user/lists']);
}else{
return '删除失败';
}
}
}

Model:

<?php
namespace frontend\models;
use Yii;
/**
* This is the model class for table "user".
*
* @property int $id 自增id
* @property string $username 用户名
* @property string $pwd 密码
* @property string $nickname
* @property int $status
* @property int $create_time
*/
class User extends \yii\db\ActiveRecord
{
/**
* {@inheritdoc}
*/
public static function tableName()
{
return 'user';
}
/**
* {@inheritdoc}
*/
public function rules()
{
return [
[['username', 'pwd', 'nickname', 'status', 'create_time'], 'required'],
[['status', 'create_time'], 'integer'],
[['username', 'nickname'], 'string', 'max' => 50],
[['pwd'], 'string', 'max' => 255],
];
}
/**
* {@inheritdoc}
*/
public function attributeLabels()
{
return [
'id' => '自增id',
'username' => '账号',
'pwd' => '密码',
'nickname' => '昵称',
'status' => '状态',
'create_time' => '创建时间',
];
}
//密码加密
public function setPassword($password){
return Yii::$app->getSecurity()->generatePasswordHash($password);
}
}

view文件夹下的default.php页面:

<?php
use yii\helpers\Html;
use yii\widgets\ActiveForm;
use yii\helpers\Url;
?>
<?php $form = ActiveForm::begin([
'action'=>Url::to(['user/upd']),
'method'=>'post'
]) ?>
<?= $form->field($data, 'username') ?>
<?= $form->field($data,'nickname') ?>
<?= $form->field($data,'status')->radioList([1=>'启用',2=>'禁用']) ?>
<?= Html::hiddenInput("id",$data->id) ?>
<?= Html::submitButton('修改', ['class' => 'btn btn-primary']) ?>
<?php ActiveForm::end() ?>

view文件夹下的index.php页面:

<?php
use yii\helpers\Html;
use yii\widgets\ActiveForm;
use yii\helpers\Url;
?>
<?php $form = ActiveForm::begin([
'action'=>Url::to(['user/create']),
'method'=>'post'
]) ?>
<?= $form->field($model, 'username') ?>
<?= $form->field($model, 'pwd')->passwordInput() ?>
<?= $form->field($model,'nickname') ?>
<?= Html::submitButton('添加', ['class' => 'btn btn-primary']) ?>
<?php ActiveForm::end() ?>

view文件夹下的lists.php页面:

<?php
use yii\helpers\Html;
use yii\widgets\LinkPager;
use yii\helpers\Url;
?>
<table border="1">
<tr>
<th>ID</th>
<th>账号</th>
<th>密码</th>
<th>昵称</th>
<th>状态</th>
<th>创建时间</th>
<th>操作</th>
</tr>
<?php foreach ($data as $k => $v): ?>
<tr>
<td><?= Html::encode($v['id']) ?></td>
<td><?= Html::encode($v['username']) ?></td>
<td><?= Html::encode($v['pwd']) ?></td>
<td><?= Html::encode($v['nickname']) ?></td>
<td><?= Html::encode($v['status']==1 ? '启用' : '禁用') ?></td>
<td><?= Html::encode(date("Y-m-d H:i:s",$v['create_time'])) ?></td>
<td>
<a href="<?php echo Url::to(['user/default','id'=>$v['id']]) ?>">修改</a>
<a href="<?php echo Url::to(['user/del','id'=>$v['id']]) ?>">删除</a>
</td>
</tr>
<?php endforeach; ?>
</table>
<?= LinkPager::widget(['pagination' => $pagination]) ?>

数据库:

CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增id', `username` varchar(50) NOT NULL COMMENT '用户名', `pwd` varchar(255) NOT NULL COMMENT '密码', `nickname` varchar(50) NOT NULL, `status` tinyint(4) NOT NULL, `create_time` int(11) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=58 DEFAULT CHARSET=utf8;

Yii2增删改查的更多相关文章
- yii2增删改查及AR的理解
yii2增删改查 // 返回 id 为 1 的客户 $customer = Customer::findOne(1); // 返回 id 为 1 且状态为 *active* 的客户 $customer ...
- yii2 增删改查
自己总结的yii2 advanced 版本的简单的增删改查,希望对大家有所帮助 1.gii生成的actionCreate()方法中 获取插入语句的id $id = $model->attribu ...
- 原生YII2 增删改查的一些操作(非ActiveRecord)
1.添加数据 如下,使用insert方法:t_admin_user为数据表名..其他的是属性.. $num = Yii::$app->db->createCommand()->ins ...
- yii2增删改查操作
https://www.yiichina.com/tutorial/996 https://www.yiichina.com/tutorial/834 一.新增 使用model::save()操作进行 ...
- [YII2] 增删改查2
一.新增 使用model::save()操作进行新增数据 $user= new User; $user->username =$username; $user->password =$pa ...
- Yii2.0高级框架数据库增删改查的一些操作(转)
yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...
- Yii2.0高级框架数据库增删改查的一些操作
yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...
- YII2.0 数据库增删改查
/*==================== dkhBaseModel 数据库增删改查方法 start ================================*/ //新增一条数据 publ ...
- yii2.0增删改查实例讲解
yii2.0增删改查实例讲解一.创建数据库文件. 创建表 CREATE TABLE `resource` ( `id` int(10) NOT NULL AUTO_INCREMENT, `textur ...
随机推荐
- systemd service 设置limit,不生效问题
参考博文: http://smilejay.com/2016/06/centos-7-systemd-conf-limits/(解决方法参考此博文) 问题简述:Centos7下修改系统的最大文件打 ...
- SQL特殊comment语法
SQL 注释的特殊用法: /*!版本号 语句*/ 表示大于等于某个版本是,才执行相应的语句. 在版本为5.7.23的MySQL上做测试如下: 测试1 mysql> select 1 /*!507 ...
- 关于音频总线IIS的学习---Verilog
关于音频总线IIS的学习---Verilog 主要思想: 在分析寄存器的值变化的时候,将时钟的边沿分两边来看,边沿之前,边沿之后,在always 块语句里面用来分析判断的寄存器的值,都应该用边沿变化之 ...
- 【C++】读取参数的类
在C++程序中,如果我们把程序中的参数都保存在txt文本中,运行时再去读取.这样的好处是,当我们需要调参的时候,不需要每次都重新编译程序,大大提升了效率. 今日分享一份实现以上功能的代码,代码来源:h ...
- xcopy命令总结
xcopy命令总结1.拷贝多个文件和目录用xcopy /yhie或者xcopy /yhis命令,注意目标路径要以\结尾,例如:xcopy /yhie *.* e:\xxx\2.拷贝多个固定名字的文件用 ...
- The perception and large margin classifiers
假设样例按照到来的先后顺序依次定义为.为样本特征,为类别标签.任务是到来一个样例,给出其类别结果的预测值,之后我们会看到真实值,然后根据真实值来重新调整模型参数,整个过程是重复迭代的过程,直到所有的样 ...
- 实验一:通过bridge-utils工具创建网桥并实现网络连接
实验名称: 通过bridge-utils工具创建网桥并实现网络连接 实验环境: 实验要求: 安装bridge-utils工具,创建网桥br0,通过brctl命令,为网桥配置IP地址192.168.23 ...
- (dev mode) install CONSUL on ubuntu
WSL: V18.04.1 1. install $sudo apt-get update$sudo apt-get install consul wsl1017@DESKTOP-14G6K9S:~$ ...
- springboot2.0动态多数据源切换
摘要:springboot1.x到springboot2.0配置变化有一点变化,网上关于springboot2.0配置多数据源的资料也比较少,为了让大家配置多数据源从springboot1.x升级到s ...
- 某大型跨境电商JVM调优总结
前提:某大型跨境电商业务发展非常快,线上机器扩容也很频繁,但是对于线上机器的运行情况,特别是jvm内存的情况,一直没有一个统一的标准来给到各个应用服务的owner.经过618大促之后,和运维的同学讨论 ...