关于模型部分參考http://blog.csdn.net/buyingfei8888/article/details/40208729

控制器部分:

<?php
class GoodsController extends Controller{
function actionShow(){
$goods_model = Goods::model(); //简单查询能够通过模型里面静态方法来创建
$sql = "select goods_id,goods_name,goods_price,goods_create_time from {{goods}} limit 10";
$goods_infos = $goods_model ->findAllBySql($sql);//通过原生态sql进行查询。findALlBySql返回一个对象数组,
// var_dump($goods_infos);
// foreach($goods_infos as $v){
// echo $v ->goods_name ."<br />";
// }
// exit();
$this->render('show',array("goods_infos"=>$goods_infos)); //这样的方式会渲染布局
//$this->renderPartial('add',array('goods_model' => $goods_model)); //这样的方式不会渲染布局
} function actionAdd(){
$goods_model = new Goods();
if(isset($_POST['Goods'])){
// $goods_model->goods_name = 'apple phone';
// $goods_model->goods_price = '5199';
// $goods_model->goods_weight=102;
//对上面代码优化
foreach($_POST['Goods'] as $_k => $_v){
$goods_model -> $_k = $_v;
}
}
if($goods_model->save()){
$this ->redirect('./index.php?r=houtai/goods/show');
}else{
echo "error";
}
// $this->renderPartial('add',array('goods_model' => $goods_model));
} /*
* YII 对get优化,作为參数传递进来
* 模板和加入时模板基本一样。直接复制略微改动即可。都是通过小物件 ,自己主动会把数据关联起来,节省开发成本
*/
function actionUpdate($id){
//除了加入数据进行 new Goods()。 别的都是调用静态方法 调用save方法运行是insert
// Goods::model()调用save方法运行是update
$goods_model = Goods::model();
$goods_info = $goods_model ->findByPk($id); //$goods_info 是 数据模型对象
if(isset($_POST['Goods'])){
foreach($_POST['Goods'] as $_k => $_v){
$goods_info -> $_k = $_v;
} if($goods_info -> save()){
$this ->redirect('./index.php?r=houtai/goods/show');
}
}
$this->renderPartial('update',array('goods_model' => $goods_info ));
}
function actionDel($id){
//依据$id获得被删除数据对象。通过该对象调用delete方法就ok
$goods_mode = Goods::model();
$goods_info = $goods_mode ->findByPk($id); //获得被删除商品模型对象
if($goods_info ->delete() ){
$this ->redirect('./index.php?r=houtai/goods/show');
}else{
echo 'error';
} }
function actionJia(){
$goods_model = new Goods();
// $goods_model=Goods::model();
$goods_model->goods_name = 'apple phone';
$goods_model->goods_price = '5199';
$goods_model->goods_weight=102;
var_dump($goods_model->save());
// var_dump($goods_model);
if($goods_model->save()){
echo 'success';
}else{
echo "error";
} }
}
?>

通过这个url(http://localhost/shop/index.php?r=houtai/goods/show)show视图:

部分源代码:

<table class="table_a" border="1" width="100%">
<tbody><tr style="font-weight: bold;">
<td>序号</td>
<td>商品名称</td>
<td>库存</td>
<td>价格</td>
<td>图片</td>
<td>缩略图</td>
<td>品牌</td>
<td>创建时间</td>
<td align="center">操作</td>
</tr>
<?php
$i=1;
foreach($goods_infos as $_v){
?>
<tr id="product1">
<td><?php echo $i++;? ></td>
<td><a href="#">苹果(APPLE)iPhone 4S<? php echo $_v->goods_name;?></a></td>
<td><?php echo $_v->goods_number;?></td>
<td><? php echo $_v->goods_price ;?></td>
<td><img src="<?PHP ECHO HOUTAI_IMG_URL ;?><?php echo $_v->goods_big_img;? >" height="60" width="60"></td>
<td><img src="<?PHP ECHO HOUTAI_IMG_URL ;?><?php echo $_v->goods_small_img;? >" height="40" width="40"></td>
<td><?php echo $_v->goods_brand_id;? ></td>
<td><?php echo $_v->goods_create_time;? ></td>
<td><a href="./index.php?r=houtai/goods/update&id=<?php echo $_v->goods_id;?>">改动</a></td>
<!-- <td><a href="./index.php?r=houtai/goods/update&id=<? php// echo $_v->goods_id;?>&name=test">改动</a></td>-->
<td><a href="./index.php?r=houtai/goods/del&id=<? php echo $_v->goods_id;? > "> 删除</a></td>
</tr>
<? php }
? > <tr>
<td colspan="20" style="text-align: center;">
[1]
</td>
</tr>
</tbody>
</table>

add模板部分源代码:

           <?

php $form =  $this ->  beginWidget("CActiveForm");?>
<!-- 调用了 CActiveForm 类
如何查找CActiveForm类。在\framework\yiilite.php 里查找,这个文件10000多行。可见yii核心代码就是这么多行
通过这个在找到 CActiveForm所在文件 CActiveForm.php包括了非常多方法。 就是对表单元素操作
-->
<table border="1" width="100%" class="table_a">
<tr>
<!-- <td>商品名称</td>-->
<!-- <td><input type="text" name="f_goods_name" /></td>-->
<td><? php echo $form->labelEx($goods_model,'goods_name');? ></td>
<td><?php echo $form -> textField($goods_model,'goods_name');? ></td>
</tr>
<tr> <td><?php echo $form->labelEx($goods_model,'goods_weight');? ></td>
<td> <?php echo $form -> textField($goods_model,'goods_weight');?></td>
</tr>
<tr> <td><?php echo $form->labelEx($goods_model,'goods_price');?></td>
<td> <?php echo $form -> textField($goods_model,'goods_price');?></td>
</tr>
<tr> <td><?php echo $form->labelEx($goods_model,'goods_number');?></td>
<td> <?php echo $form -> textField($goods_model,'goods_number');?></td>
</tr>
<tr> <td><?php echo $form->labelEx($goods_model,'goods_category_id');?></td>
<td> <? php echo $form -> textField($goods_model,'goods_category_id');? ></td>
</tr>
<tr> <td><? php echo $form->labelEx($goods_model,'goods_brand_id');? ></td>
<td><? php echo $form -> textField($goods_model,'goods_brand_id');? ></td>
</tr>
<tr> <td><?php echo $form->labelEx($goods_model,'goods_introduce');?></td>
<td><?php echo $form -> textArea($goods_model,'goods_introduce',array('cols' => 20,"rows" => 5));?></td>
</tr>
</table>
<td colspan="2" align="center">
<input type="submit" value="加入">
</td>
<?php $this->endWidget();?>

改动和上面基本同样:

<?php $form =  $this ->  beginWidget("CActiveForm");?

>
<!-- 调用了 CActiveForm 类
如何查找CActiveForm类。在\framework\yiilite.php 里查找,这个文件10000多行,可见yii核心代码就是这么多行
通过这个在找到 CActiveForm所在文件 CActiveForm.php包括了非常多方法。就是对表单元素操作
-->
<table border="1" width="100%" class="table_a">
<tr>
<!-- <td>商品名称</td>-->
<!-- <td><input type="text" name="f_goods_name" /></td>-->
<td><?php echo $form->labelEx($goods_model,'goods_name');?></td>
<td><? php echo $form -> textField($goods_model,'goods_name');?></td>
</tr>
<tr> <td><? php echo $form->labelEx($goods_model,'goods_weight');? ></td>
<td> <?php echo $form -> textField($goods_model,'goods_weight');?></td>
</tr>
<tr> <td><?php echo $form->labelEx($goods_model,'goods_price');?></td>
<td> <? php echo $form -> textField($goods_model,'goods_price');? ></td>
</tr>
<tr> <td><? php echo $form->labelEx($goods_model,'goods_number');?></td>
<td> <?php echo $form -> textField($goods_model,'goods_number');?></td>
</tr>
<tr> <td><?php echo $form->labelEx($goods_model,'goods_category_id');?></td>
<td> <?php echo $form -> textField($goods_model,'goods_category_id');?></td>
</tr>
<tr> <td><?php echo $form->labelEx($goods_model,'goods_brand_id');?></td>
<td><?php echo $form -> textField($goods_model,'goods_brand_id');?></td>
</tr>
<tr> <td><? php echo $form->labelEx($goods_model,'goods_introduce');?></td>
<td><? php echo $form -> textArea($goods_model,'goods_introduce',array('cols' => 20,"rows" => 5));?></td>
</tr>
</table>
<td colspan="2" align="center">
<input type="submit" value="改动">
</td>
<?php $this->endWidget();? >

关于为什么Goods::model()和new  Goods() 运行save方法会分别调用update 和insert方法能够看CActiveRecord 源代码。

YII进行数据增删改查分析的更多相关文章

  1. salesforce 零基础开发入门学习(六)简单的数据增删改查页面的构建

    VisualForce封装了很多的标签用来进行页面设计,本篇主要讲述简单的页面增删改查.使用的内容和设计到前台页面使用的标签相对简单,如果需要深入了解VF相关知识以及标签, 可以通过以下链接查看或下载 ...

  2. C#操作Excel数据增删改查(转)

    C#操作Excel数据增删改查. 首先创建ExcelDB.xlsx文件,并添加两张工作表. 工作表1: UserInfo表,字段:UserId.UserName.Age.Address.CreateT ...

  3. C#操作Excel数据增删改查示例

    Excel数据增删改查我们可以使用c#进行操作,首先创建ExcelDB.xlsx文件,并添加两张工作表,接下按照下面的操作步骤即可 C#操作Excel数据增删改查. 首先创建ExcelDB.xlsx文 ...

  4. 【转载】salesforce 零基础开发入门学习(六)简单的数据增删改查页面的构建

    salesforce 零基础开发入门学习(六)简单的数据增删改查页面的构建   VisualForce封装了很多的标签用来进行页面设计,本篇主要讲述简单的页面增删改查.使用的内容和设计到前台页面使用的 ...

  5. Yii数据库操作增删改查-[增加\查询\更新\删除 AR模式]

    在Yii的开发中常常需要去使用Yii的增删改查方法,这些方法又可以多次变化和组合,带来全方位的实现对数据库的处理,下面对这些方法做一些简单的整理和梳理,有遗漏或是BUG,敬请指出.灰常感谢!!! 一. ...

  6. 一个在ASP.NET中利用服务器控件GridView实现数据增删改查的例子

    备注:这是我辅导的一个项目开发组的一个例子,用文章的方式分享出来,给更多的朋友参考.其实我们这几年的项目中,都不怎么使用服务器控件的形式了,而是更多的采用MVC这种开发模式.但是,如果项目的历史背景是 ...

  7. MVC设计模式((javaWEB)在数据库连接池下,实现对数据库中的数据增删改查操作)

    设计功能的实现: ----没有业务层,直接由Servlet调用DAO,所以也没有事务操作,所以从DAO中直接获取connection对象 ----采用MVC设计模式 ----采用到的技术 .MVC设计 ...

  8. IDEA搭建SSM实现登录、注册,数据增删改查功能

     本博文的源代码:百度云盘/java/java实例/SSM实例/SSM实现登录注册,增删改查/IDEA搭建SSM实现登录,注册,增删改查功能.zip 搭建空的Maven项目 使用Intellij id ...

  9. C#在winform中操作数据库,实现数据增删改查

    1.前言: 运行环境:VS2013+SQL2008+Windows10 程序界面预览: 使用的主要控件:dataGridview和menuStrip等. 2.功能具体介绍: 1.首先,我们要先实现基本 ...

随机推荐

  1. JavaScript系列----函数(Function)篇(4)

    1.什么是函数? 在W3C中函数的定义是这么说的:函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块.   诚然,从这种抽象的定义中我们得不到什么有价值的东西.下面,举例来列举出函数的几种定义 ...

  2. 将非常规Json字符串转换为常用的json对象

    如下所示,这是一个已经转换为Json对象的非常规Json字符串,原来是一个Json类型的字符串,在转换为Json对象时,查询资料发现有两种转换法,.parse()和.eval()方法,但是前辈们都极其 ...

  3. java 分页导出百万级数据到excel

    最近修改了一个导出员工培训课程的历史记录(一年数据),导出功能本来就有的,不过前台做了时间限制(只能选择一个月时间内的),还有一些必选条件, 导出的数据非常有局限性.心想:为什么要做出这么多条件限制呢 ...

  4. java操作solr实现查询功能

    一.封装的查询方法 /** * solr查询方法 * @param client solr客户端 * @param query solr查询对象 * @return list集合 * @throws ...

  5. IDEA热部署(二)---jetty插件启动maven项目

    jetty插件的配置 我们使用jetty插件来进行启动我们的maven项目,在pom.xml中进行配置: <plugins> <plugin> <groupId>o ...

  6. .NET之RabbitMQ学习笔记(一)-应用场景

    使用场景 1.异步处理 用户注册后,需要发注册邮件和注册短信,传统的做法有两种1.串行的方式;2.并行的方式 (1)串行处理方式:注册信息写数据库-发送注册邮件-发送注册短信,等上述三个操作都执行完成 ...

  7. .net core 使用X509 私钥加密请求

    1.获取证书路径 var basePath = _environment.ContentRootPath; //商户私钥证书,用于对请求报文进行签名 "); 2.数据加密 .net core ...

  8. Python 爬虫练习(二)爬取补天公益SRC厂商域名URL (2017年11月22日)

    介绍下: 补天是国内知名的漏洞响应平台,旨在企业和白帽子共赢. 白帽子在这里提交厂商漏洞,获得库币和荣誉,厂商从这里发布众测.获取漏洞报告和修复建议. 在2017年3月份之前,补天的厂商域名URL是非 ...

  9. 使用Gulp构建前端自动化方案

    前言 在刚入门前端的时候,我们并不清楚前端有工具可以帮我们自动化打包压缩文件,当时只关注能实现功能就可以了,也不太在意前端性能优化的问题,随着项目功能的复杂,项目也变得越来越大,页面的执行速度也开始变 ...

  10. 但未在用户代码中进行处理 具有固定名称“Oracle.ManagedDataAccess.Client”的 ADO.NET 提供程序未在计算机或应用程序配置文件中注册或无法加载。

    这是使用ODP.NET链接Orcl数据库常见错误,需要配置系统环境变量. 解决方法如下: 找到以下路径文件:C:\Windows\Microsoft.NET\Framework\v4.0.30319\ ...