ThinkPHP之数据库操作

数据库的操作是由模型来管理的,模型类的作用大多数情况是操作数据表的,如果按照系统的规范来命名模型类的话,大多数情况下是可以用模型的名字自动对应数据表的。 模型类的命名规则是除去表前缀的数据表名称,采用驼峰法命名,并且首字母大写,然后加上模型层的名称(默认定义是Model)(看得很懵逼对吧,我也是,上面这段话是百度的,下面实例化要好好看了)

TP提供了快捷实例化模型的API,上面的直接实例化的时候我们需要传入完整的类名,系统提供了一个快捷方法D用于数据模型的实例化操作。 要实例化自定义模型类,可以使用下面的方式:

一、数据写入

向user数据表中写入一条数据

$user = M('user'); //实例化user对象,user是表名

$data['id'] = 5;

$data['username'] = benny;

$user->add('$data');

二、数据查询

1、读取数据集

$user = M('user');

$map['id'] = I('id',0,'int');

//find()方法,读取数据表中的一行数据(或者关联数据)

$data = $user->where(array('id'=>$map['id']))->find(); //array('id'=>$map['id'])等同于$map

dump($data);

find方法查询数据的时候可以配合相关的连贯操作方法,其中最关键的则是where方法。 如果查询出错,find方法返回false,如果查询结果为空返回NULL,查询成功则返回一个关联数组(键值是字段名或者别名)。

读取数据集其实就是获取数据表中的多行记录(以及关联数据),使用select方法

$user = M('user');

//查找select值为1的用户数据,以创建时间排序 ,返回10条数据

$data = $user->where('status = 1')->order('create_time')->limit(10)->select();

如果查询出错,select的返回值是false,如果查询结果为空,则返回NULL,否则返回二维数组。

读取字段值其实就是获取数据表中的某个列的多个或者单个数据,最常用的方法是 getField方法。

$user = M('user');

//获得id为1 的用户的username

$data = $user->where(‘id =1 ’)->getField('username');

2、数据更新

更新数据使用save方法

$user = M('user'); //实例化user对象,user是表名

$data['username'] = benny;

$data['password'] = 123;

$user->where('id = 1 ')->save('$data');//根据条件更新记录

如果只是更新个别字段的值,可以使用setField方法。

$user = M('user');

//更改用户的username

$data = $user->where(‘id =1 ’)->setField('username','benny');

setField方法支持同时更新多个字段,只需要传入数组即可,

$user = M('user');

//更改用户的username 和password

$data = array('username'=>'benny','password'=>'123');

$data = $user->where(‘id =1 ’)->setField($data);

3、数据删除

ThinkPHP删除数据使用delete方法

$user = M('user');

$user->delete(1);

表示删除主键为1的数据,delete方法可以删除单个数据,也可以删除多个数据,这取决于删除条件

delete方法的返回值是删除的记录数,如果返回值是false则表示SQL出错,返回值如果为0表示没有删除任何数据。 也可以用order和limit方法来限制要删除的个数:

$user->where('id = 1')->order('create_time')->limit('5')->delete();

为了避免错删数据,如果没有传入任何条件进行删除操作的话,不会执行删除操作

(原文写于2017.8.16)

原文发布于微信公众号 - 程序员的碎碎念(gh_53e607dd4782)

原文发表时间:2017-08-29

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Android 研究

Java虚拟机基础——2JVM运行时数据区

本篇文章主要讲解JVM运行时数据区,所以我们按照线程是否私有的维度将本篇文章一分为二,分为线程私有数据区和所有线程共有的数据区。而在线程私有的数据区又可以分为程...

885
来自专栏Python

Django视图层之路由配置系统(urls)

视图层之路由配置系统(urls) URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL与要为该URL调用的视图函数之间的映射表;你就...

1939
来自专栏Java帮帮-微信公众号-技术文章全总结

SpringMVC Controller单例和多例

SpringMVC Controller单例和多例 对于SpringMVC Controller单例和多例,下面举了个例子说明下. 第一次:类是多例,一个普通属...

4168
来自专栏Python专栏

python如何定时异步执行任务

1573
来自专栏机器学习从入门到成神

Spring在 IOC 容器中 Bean 之间的关系

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_35512245/articl...

801
来自专栏杂七杂八

列表、字典、集合中筛选数据

传统迭代法 data = [1,5,-3,-2,8,0,9] res = [] for x in data: if x >=0: res...

3486
来自专栏Golang语言社区

厚土Go学习笔记 | 26. 函数闭包

如果非必要,尽量不要在程序中使用闭包。 go函数可以是一个闭包。闭包是一个函数值,它引用了函数体之外的变量。这个函数可以对这个变量进行访问和赋值。 展示一个例子...

34813
来自专栏PHP在线

了解这些PHP小技巧吗?

1. $_POST并非是HTTP POST过来的数据, 如json格式的数据就没法接受,这是因为由于历史原因,php只能解析Content-Type为 appl...

2666
来自专栏Java编程技术

伪共享

计算机系统中为了解决主内存与CPU运行速度的差距,在CPU与主内存之间添加了一级或者多级高速缓冲存储器(Cache),这个Cache一般是集成到CPU内部的,所...

623
来自专栏PHP在线

了解这些PHP小技巧吗?

1. $_POST并非是HTTP POST过来的数据, 如json格式的数据就没法接受,这是因为由于历史原因,php只能解析Content-Type为 appl...

2585

扫码关注云+社区