二、模型操作方法select()--查询语句
         //查询级别管理列表信息
    public function levellists() {

$lelists = $this->level->select();//查询语句方法

include $this->admin_tpl('level_list');//加载后台级别管理列表的模板
          }
         模型select()方法,默认情况下查询fb_level表所有字段的信息,上面的levellists()方法如果转化为mysql语句为:
         
         public function levellists() {

$sql="select * from fb_level ";//sql查询语句方法

$lelists=$this->level->query($sql);

include $this->admin_tpl('level_list');//加载后台级别管理列表的模板
              }
  查询获取的数据列表如图:

三、模型操作方法update()--更新语句
//修改级别信息

public function editlevel() {

if(isset($_get['id'])){//获取要修改的级别id

$id = intval($_get['id']);

if(!$id) showmessage("操作失败");//如果获取的id为空,则返回操作提示信息

if(isset($_post['dosubmit'])) {

$this->level->update($_post['level'], array('id' => $id));

} else {

$where = array('id' => $_get['id']);//查询条件,是一个数组

$level_info = $this->level->get_one($where);//get_one()模型方法,获取一条记录

include $this->admin_tpl('level_edit');//加载后台级别修改的模板

}

}

}
 写成等效的mysql语句
  public function editlevel() {

if(isset($_get['id'])){//获取要修改的级别id

$id = intval($_get['id']);

if(!$id) showmessage("操作失败");//如果获取的id为空,则返回操作提示信息

if(isset($_post['dosubmit'])) {

$sql="update fb_level set level = '".$_post['level']."' where id = '".$id."' ";

$lelists=$this->level->query($sql);

} else {

$where = array('id' => intval( $_get['id']));//查询条件,是一个数组

$level_info = $this->level->get_one($where);//get_one()模型方法,获取一条记录

include $this->admin_tpl('level_edit');//加载后台级别修改的模板

}

}

}

修改别级效果图:

四、模型操作方法delete()--删除语句
//删除级别信息 
public function dellevel() {
  
  if(isset($_get['id'])){

$levelid = intval($_get['id']);

$result = $this->level->delete(array('id'=>$levelid));//模型删除语句

if($result){//返回删除结果提示信息

showmessage(l("操作成功"),'?m=football&c=level&a=levellists');

}else {

showmessage(l("操作失败"),'?m=football&c=level&a=levellists');

}


 }
同样道理,写成等效的mysql的删除语句如
  
public function dellevel() {
  
  if(isset($_get['id'])){

$id = intval($_get['id']);

$result=$this->level->query("delete from `fb_level` where `id` in ($id )");

if($result){//返回删除结果提示信息

showmessage(l("操作成功"),'?m=football&c=level&a=levellists');

}else {

showmessage(l("操作失败"),'?m=football&c=level&a=levellists');

}


 }

至此,明白模型类model.class.php的查询、添加、修改、删除数据的运用,我们就可以在phpcms v9二次开发中根据需求随心所欲地开发自己的模块。

phpcms v9二次开发之模型类的应用(2)的更多相关文章

  1. phpcms v9二次开发之模型类的应用(1)

    在<phpcms二次开发之模型类model.class.php>中讲到了模型类的建立方法,接下来我讲一下模型类的应用.      前段时间我基于phpcms v9开发了一个足球网.足球网是 ...

  2. phpcms v9二次开发之数据模型类

    系统模型类:model.class.php数据模型类的位置:/phpcms/libs/classes phpcms v9二次开发中,我们要经常需要对模块的数据表进行查询.添加.修改和删除数据等操作,所 ...

  3. PHPCMS V9二次开发便捷自定义后台入口文件夹

    phpcms v9二次开发便捷自定义后台入口文件夹 最新发布的phpcms v9由于采用了mvc的设计模式,所以它的后台访问地址是固定的,虽然可以通过修改路由配置文件来实现修改,但每次都修改路由配置文 ...

  4. PHPCMS V9二次开发]自定义字段模型-文本组

    phpcms v9,我们在做类似于酒店房型等类型的时候,需要用到文本组字段模型,但phpcms并未提供该模型.如下图所示效果: 展示效果如下: 步骤/方法 打开phpcms\modules\conte ...

  5. phpcms v9二次开发笔记

    phpcms是基于MVC结构的. 安装: 下载phpcms_v9.5.9_UTF8.zip:新建目录phpcms,将压缩包里install_package目录下所有文件复制到phpcms目录.浏览器输 ...

  6. phpcms V9 二次开发------(获取点击数详解)

    关于phpcms V9的点击数的使用应该有不少数是直接调用网上搜索到的代码,但是对于一些想要深入研究开发的人来说,看到网上的代码后更是不解,本人这几天看了看,了解了一些东西,在这里写出来分享一下,首先 ...

  7. [PHPCMS V9二次开发]自定义字段模型-添加字段类型

    步骤/方法 打开phpcms\modules\content\fields目录,复制文件夹downfiles,并改名为textgroups. 打开phpcms\modules\content\fiel ...

  8. phpcms v9 二次开发 - 自己添加源文件

    一.在根目录添加入口文件, 我现在要在根目录添加一个文件名为test.php 这样一个文件,为了调用系统的公用类和函数,必须加入一下包含文件 test.php代码如下 <?phpdefine(' ...

  9. PHPCMS V9 二次开发常用代码集

    0:调用最新文章,带所在版块 {pc:get sql="SELECT a.title, a.catid, b.catid, b.catname, a.url as turl ,b.url a ...

随机推荐

  1. BeanUtils API中使用ConvertUtils向BeanUtils注册一个日期转换器

    ConvertUtils.register(new Converter(){ public Object convert(Class type, Object value){ if(value == ...

  2. 未能找到类型或命名空间名称“XXXX”(是否缺少 using 指令或程序集引用?) 转

    未能找到类型或命名空间名称“XXXX”(是否缺少 using 指令或程序集引用?)   项目中 App_Code 文件夹中的类的命名空间,在添加的页面的  using XXXX  时,提示 未能找到类 ...

  3. Java学习日记-2.4 浮点数

    http://wenku.baidu.com/view/e68b2ed5312b3169a451a4e2.html

  4. F - True Liars - poj1417(背包+并查集)

    题意:有这么一群人,一群好人,和一群坏人,好人永远会说实话,坏人永远说假话,现在给你一组对话和好人与坏人的数目P1, P2. 数据里面的no是A说B是坏人, yes代表A说B是好人,就是这样,问题能不 ...

  5. 我理解的javascript单线程机制

    废话不多说,我们先来看几个例子: 1. setTimeout( console.log(2); result:  2 1   2.   console.log(100 setTimeout( cons ...

  6. Sublime Text 2.0.2 注册码

    Sublime Text 2.0.2 注册码 直接输入注册码就可以了----- BEGIN LICENSE -----Andrew WeberSingle User LicenseEA7E-85560 ...

  7. web服务交互中HTTP数据内容GZIP,ZLIB格式压缩与解压缩封装(共享)

    点击下载独立的dll //dll内部封装API格式 //gzip BOOL fnZlibDecompressPacket (__IN_PARAM unsigned char* gZlibDataBuf ...

  8. uva 317 - Hexagon(规律推导)

    题目连接:317 - Hexagon 题目大意:在一个19个六边形组成的图形上玩一个游戏,给出9个数字, 分成3组, 分别可以填在左上角, 上, 有上角,因为对于小六边形来说, 对边的数是相同的, 然 ...

  9. spring05配置文件之间的关系

    一:配置文件包含关系 1.创建对应的实体类 public class Student { //学生实体类 private String name; //姓名 private Integer age; ...

  10. Linux基础知识之 系统启动流程

    [1]Linux启动的几个主要阶段 启动流程示意图