TP3快速入门

Wesley13
• 阅读 595

一、查询

  D方法实例化模型类的时候通常是实例化某个具体的模型类,如果你仅仅是对数据表进行基本的CURD操作的话,使用M方法实例化的话,由于不需要加载具体的模型类,所以性能会更高。

$map = array();
$map['u.store_id'] = array('eq',0);
$map['u.reg_time'] = array('egt',time());
$map['u.user_rank'] = array('in',array(0,9));

$group = '';
$order = '';
//查询10-20的数据集
$list = M('users u')->field('u.user_id,u.user_name,u.store_id')
    ->join('LEFT JOIN __ORDER_INFO__ oi ON oi.user_id=u.user_id')
    ->where($map)
    ->limit(10,20)
    ->group($group)
    ->order($order)
    ->select();

//读取数据表中的一行数据(或者关联数据),主要通过find方法完成
//如果查询出错,find方法返回false,如果查询结果为空返回NULL,查询成功则返回一个关联数组(键值是字段名或者别名)。
$data = M('users')->where('status=1 AND name="thinkphp"')->find();

//读取字段值其实就是获取数据表中的某个列的多个或者单个数据,最常用的方法是 getField方法。
//默认情况下,当只有一个字段的时候,返回满足条件的数据表中的该字段的第一行的值。
$nickname = M("User")->where('id=3')->getField('nickname');
//如果需要返回整个列的数据,可以用:
$nickname = M("User")->getField('id',true);
//如果传入多个字段的话,默认返回一个关联数组:
$list = M("User")->getField('id,nickname');

//获取用户数:
$userCount = M("User")->count();

//原生sql查询
$Model = new \Think\Model() // 实例化一个model对象 没有对应任何数据表
$Model->query("select * from think_user where status=1");

//打印SQL
echo M()->_sql();

二、更新

$data = array();
$data['name'] = 'ThinkPHP';
$data['email'] = 'ThinkPHP@gmail.com';
M("User")->where('id=5')->save($data); // 根据条件更新记录

//原生sql执行修改、删除
$Model = new \Think\Model() // 实例化一个model对象 没有对应任何数据表
$Model->execute("update think_user set name='thinkPHP' where status=1");

三、删除

M("User")->where('id=5')->delete(); // 删除id为5的用户数据

 四、插入

$data['name'] = 'ThinkPHP';
$data['email'] = 'ThinkPHP@gmail.com';
M("User")->add($data);

// 批量添加数据
$dataList[] = array('name'=>'thinkphp','email'=>'thinkphp@gamil.com');
$dataList[] = array('name'=>'onethink','email'=>'onethink@gamil.com');
$User->addAll($dataList);

五、接受参数、跳转、重定向、判断请求类型、ajax返回、显示页面

//判断请求类型
IS_GET  IS_POST IS_AJAX

//接受参数 I方法是ThinkPHP用于更加方便和安全的获取系统输入变量,可以用于任何地方,用法格式如下:
//I('变量类型.变量名/修饰符',['默认值'],['过滤方法或正则'],['额外数据源'])
I('post.name','','htmlspecialchars'); // 采用htmlspecialchars方法对$_POST['name'] 进行过滤,如果不存在则返回空字符串

//跳转、重定向
//系统的\Think\Controller类内置了两个跳转方法success和error,用于页面跳转提示,而且可以支持ajax提交。
//success和error方法的第一个参数表示提示信息,第二个参数表示跳转地址,第三个参数是跳转时间(单位为秒),例如:
// 操作完成3秒后跳转到 /Article/index
$this->success('操作完成','/Article/index',3);
// 操作失败5秒后跳转到 /Article/error
$this->error('操作失败','/Article/error',5);

//Controller类的redirect方法可以实现页面的重定向功能。
//redirect方法的参数用法和U函数的用法一致(参考URL生成部分),例如:
//重定向到New模块的Category操作
$this->redirect('New/category', array('cate_id' => 2), 5, '页面跳转中...');
//上面的用法是停留5秒后跳转到New模块的category操作,并且显示页面跳转中字样,重定向后会改变当前的URL地址。
//如果你仅仅是想重定向要一个指定的URL地址,而不是到某个模块的操作方法,可以直接使用redirect函数重定向,例如:
//重定向到指定的URL地址
$this->redirect('/New/category/cate_id/2', 5, '页面跳转中...');

//ajax返回
//ThinkPHP可以很好的支持AJAX请求,系统的\Think\Controller类提供了ajaxReturn方法用于AJAX调用后返回数据给客户端。并且支持JSON、JSONP、XML和EVAL四种方式给客户端接受数据,并且支持配置其他方式的数据格式返回。ajaxReturn方法调用示例:
$data['status']  = 1;
$data['content'] = 'content';
$this->ajaxReturn($data,'json');

//显示页面
$this->display();
//或
$this->display('模板地址');

六、模板标签

1、Volist

//volist标签通常用于查询数据集(select方法)的结果输出,通常模型的select方法返回的结果是一个二维数组,可以直接使用volist标签进行输出。 在控制器中首先对模版赋值:
$list = M('User')->limit(10)->select();
$this->assign('list',$list);

//在模版定义如下,循环输出用户的编号和姓名:
<volist name="list" id="vo">
    {$vo.id}:{$vo.name}<br/>
</volist>

//支持输出查询结果中的部分数据,例如输出其中的第5~15条记录
<volist name="list" id="vo" offset="5" length='10'>
{$vo.name}
</volist>

//输出循环变量
<volist name="list" id="vo" key="k" >
{$k}.{$vo.name}
</volist>

//如果没有指定key属性的话,默认使用循环变量i,例如:
<volist name="list" id="vo"  >
{$i}.{$vo.name}
</volist>
    
//如果要输出数组的索引,可以直接使用key变量,和循环变量不同的是,这个key是由数据本身决定,而不是循环控制的,例如:
<volist name="list" id="vo"  >
{$key}.{$vo.name}
</volist>

2、Foreach

//foreach标签类似与volist标签,只是更加简单,没有太多额外的属性,例如:
<foreach name="list" item="vo">
    {$vo.id}:{$vo.name}
</foreach>
name表示数据源 item表示循环变量。

可以输出索引,如下:
<foreach name="list" item="vo" >
    {$key}|{$vo}
</foreach>

也可以定义索引的变量名
<foreach name="list" item="vo" key="k" >
   {$k}|{$vo}
</foreach>

3、比较(eq或者equal、neq或者notequal、gt、egt、lt、elt、heq、nheq)

//比较标签用于简单的变量比较,复杂的判断条件可以用if标签替换,比较标签是一组标签的集合,基本上用法都一致,如下:
<比较标签 name="变量" value="值">
    内容
</比较标签>
//通常比较标签的值是一个字符串或者数字,如果需要使用变量,只需要在前面添加“$”标志: 当vo对象的属性等于$a就输出
<eq name="vo:name" value="$a">{$vo.name}</eq>

 4、范围(in、notin、between、notbetween)

//范围判断标签包括in notin between notbetween四个标签,都用于判断变量是否中某个范围。
<in name="id" value="1,2,3">
  id在范围内
<else/>
  id不在范围内
</in>

5、IF

<if condition="($name eq 1) OR ($name gt 100) "> value1
<elseif condition="$name eq 2"/>value2
<else /> value3
</if>
点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
java设计模式1
1:单例模式简介  单例模式是一种常用的软件设计模式,它确保某个类只有一个实例,而且自行实例化并向整个系统提供唯一的实例。总而言之就是在系统中只会存在一个对象,其中的数据是共享的  特点:    单例类只能有一个实例,所以一般会用static进行修释。    单例类必须自己创建自己的唯一实例。也就是在类中要new一个自己。    单例类必
Wesley13 Wesley13
3年前
java中static的作用详解
java中static关键字表示静态的意思,主要用于以下三点,static成员变量,static成员方法和static块。在类中如果定义了static类型的对象(变量或者方法),在java虚拟机(JVM)加载类时,该对象就会被实例化,在使用的时候就不需要再去实例化,直接调用就可以了。常与private,public搭配使用。下面详细说一下这三部分。1
Wesley13 Wesley13
3年前
java8新特性
Stream将List转换为Map,使用Collectors.toMap方法进行转换背景:User类,类中分别有id,name,age三个属性。List集合,userList,存储User对象1、指定keyvalue,value是对象中的某个属性值。 Map<Integer,StringuserMap1userList.str
Wesley13 Wesley13
3年前
java中多态的实现机制
多态的概念:  简单来说就是事物在运行过程中存在的不同状态,即父类或接口定义的引用变量指向子类或具体实现类的实例对象。程序调用方法在运行期才进行动态绑定,而不是引用变量的类型中定义的方法。多态存在的前提:1、存在继承关系,子类继承父类;2、子类重写父类的方法;3、父类引用指向子类对象。具体实例:1、定义一个父类:Animal
Wesley13 Wesley13
3年前
(面试常问)4种单例设计模式的总结(内含代码以及分析)
单例设计模式:  单例模式,是一种常见的软件设计模式.在它的核心结构中只包含了一个被称为单例的特殊类.通过单例模式可以保证系统中只有该类的一个实例对象.优点:  实例控制:单例模式会阻止其它对象实例化其自己的单例对象的副本,从而确保所有对象都访问的是唯一的实例   灵活性:因为类控制了实例化过程,所以类可以很灵活的更改实
Wesley13 Wesley13
3年前
Java高级特性2
\TOC\1\.static关键字1.1类变量、类方法/static关键字类变量不用实例化,直接类名.属性名就可以使用,是类的一部分,被所有这个类的实例化所共享,也可以叫做静态变量如果想让一个类的所有实例共享数据,就用类变量!
Wesley13 Wesley13
3年前
Spring学习总结(5)——IOC注入方式总结
一、构造注入在类被实例化的时候,它的构造方法被调用并且只能调用一次。所以它被用于类的初始化操作。<constructorarg是<bean标签的子标签。通过其<value子标签可以为构造方法传递参数。现在以一个简单的输出学生信息的实例演示如何为构造方法传递参数。实例程序创建过程如下。(1)建立Student接口,
Wesley13 Wesley13
3年前
Unity中使用多构造函数
如果要实例化的类只有一个构造函数,则使用方法很简单使用方法如下:1234567using(IUnityContainercontainernew UnityContainer()){UnityConfigurationSectionsection(UnityConfigura
Wesley13 Wesley13
3年前
C#中依赖注入
由于客户类只依赖于服务类的一个接口,而不依赖于具体服务类,所以客户只定义一个注入点。在程序运行过程中,客户类部直接实例化具体服务类实例,而是客户类的运行上下文环境或者专门组建负责实例化服务类,然后将其注入到客户类中,保证客户类的正常运行。依赖注入的方法大致分为3中:接口注入、构造方法注入、setter注入;1、setter注入setter注入是指
Stella981 Stella981
3年前
CI等MVC框架中为什么不能有index控制器的原因
因为类名称是index而方法又是index,这样index函数就是php4中的构造函数,即实例化类时,直接执行这个函数而没有执行父类的构造函数,也就没有初始化CI核心类。所以会提示没有定义属性或方法了。用index类名也可以,在publicfunctionindex()方法前加上,调用父类的构造方法publicfunction\_\