关于ThinkPHP中的CURD操作

什么是CURD?

CURD就是模型操作数据表的基本操作,C(Create)、U(Update)、R(Read)、D(Delete)操作就是增删改查操作。

增加操作Create:

在mysql中增加操作使用的语法格式是:insert into 语句,而ThinkPHP中系统给我们封装了好了一个模型方法,可以通过方法来实现数据的增加操作,这个方法就是add方法:

$model -> add(一维数组);

一维数组要求必须是键值(关联)数组,键必须和数据表字段要匹配,如果不匹配则在增加的时候会被ThinkPHP过滤掉。

注意:add方法中返回值是新增记录的主键ID。

案例:往部门表中使用add方法添加一条记录。

public function addto(){
		$model = M('Dept');
		//一般添加数据为一维数组
		$data = array(
			'name' => '财务部',
			'pid' => '0',
			'sort' => '2',
			'remark' => '这是财务部门'
		);
		$result = $model -> add($data);//求将数据添加数据后的返回值
		dump($result);//打印返回值

输出结果:string(1)''1'';


如果需要添加多个数组记录怎么办?

方法一:循环使用add方法。

方法二:可以使用另外一种方法addAll方法,使用语法:$model -> addAll(参数即$data);

要求:最里面的那层数组也是关联数组(也要求键名字和数据表字段匹配),外层数组必须是下标从0开始的连续索引数组

public function addto{
$model = M('Dept');
        $data = array(
                array('name' => '人事部',
                      'pid' => '0',
                      'sort' => '3',
                      'remark' => '这是人事部门'),
                array('name' => '公关部',
                      'pid' => '0',
                      'sort' => '4',
                      'remark' => '这是公关部门')
        );
        $result = $model -> addAll($data);
        dump($result);
}

输出结果:string(2)''2''

修改操作Update:

在mysql中修改的操作语句是update table set..where..

在ThinkPHP中使用的方法叫做save方法,语法格式:save(一维关联数组);

条件是需要一维关联数组必须要包涵主键,如果没有主键信息则相当于批量修改,在ThinkPHP中系统防止误操作,不允许批量修改。如果没有主键信息则系统返回false表示没有执行而不是执行失败。

案例:使用save方法修改上述dept表格,例如修改财务部门,将sort值改为1,remark改为”开心,今天发工资“;

        public function modify(){
        	//实例化模型
        	$model = M('Dept');
        	//修改操作
        	$data = array(
                     'id' => '1',
                     'sort' => '1',
                     'remark' => '开心,今天发工资'
        	);
        	$result = $model -> save($data);
            //打印
            dump($result);
        }

输出结果:

查询操作Read:

在mysql中使用的查询操作叫做select语句。

在ThinkPHP中系统封装了两个方法帮助查询操作,分别是select方法和find方法。

select方法语法格式:

$model -> select();  表示查询全部的信息;(常用)

$model ->select(id);  表示查询指定id信息;

$model -> select('id1,id2,id3...')  表示查询指定的id集合信息,等价于mysql中的in语句;(常用)

find方法语法格式:

$model -> find();  表示查询表中第一条记录的信息,相当于limit 1;

$model -> find(id)  表示查询制定的id信息;(常用)

区别:select方法和find方法的区别在于返回值不同,select方法返回值为二维数组,即使是查询单个信息返回值也是二维数组,而find方法的返回值为一维数组。


案例:使用select方法和find方法查询dept表中的信息。

public function read(){
        	$model = M('Dept');
        	//select()方法,查询全部的信息
        	$result = $model -> select();
        	//select(id)方法,查询指定id信息
        	$result = $model -> select(1);
        	//select('id1,id2,id3...')方法,查询指定id集合信息
        	$result = $model -> select('1,2,3');
        	//find()方法,查询表中的第一条记录信息
        	$result = $model -> find();
        	//find(id)方法,查询指定id信息
        	$result = $model -> find(2);
        	dump($result);
        }

输出结果:

赋值后仅输出$result = $model -> find(2);


删除操作Delete:

在mysql中删除操作是delete from语句

在ThinkPHP中系统已经封装了一个delete方法:

语法格式:$model -> delete(id);  删除指定的id信息记录

$model -> delete('id1,id2,id3...');删除指定的id集合信息记录

注意:$model -> delete();  不能使用,删除方法必须要有条件,会返回false,系统为防止误操作禁止批量删除。  

关于删除的说明:

删除分为物理删除逻辑删除

物理删除:指真删除。

逻辑删除:指假删除,其本质是修改操作。在数据表中定义一个状态字段,比如说status,取值是0或者1,在查询的时候读取状态是1的;当用户点击删除之后触发修改操作,将状态从1修改成0。因为查询只查询状态是1的,所以0的就不会被显示在页面上。

public function amputate(){
               $model = M('Dept');
               /* $result = $model -> delete();
               该操作无法执行,返回false原因“无法批量删除”。*/
               /* $result = $model -> delete(2);
               该操作删除指定id信息*/
               $result = $model -> delete('1,3');//删除指定id集合信息
               dump($result);
        }


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ThinkPHP 进行高级的 MySQL 操作,可以使用模型来实现。模型是一种对象关系映射(ORM)工具,它允许你通过 PHP 代码来操作数据库,而不需要编写 SQL 语句。 以下是一些常见的 ThinkPHP 模型操作: 1. 查询数据 使用模型的 select() 方法可以查询数据库的数据。例如: ``` $users = UserModel::select(); ``` 可以使用 where() 方法添加查询条件。例如: ``` $users = UserModel::where('age', '>', 18)->select(); ``` 可以使用 find() 方法查询单条数据。例如: ``` $user = UserModel::where('id', 1)->find(); ``` 2. 插入数据 使用模型的 save() 方法可以插入数据到数据库。例如: ``` $user = new UserModel; $user->name = 'John'; $user->age = 20; $user->save(); ``` 3. 更新数据 使用模型的 save() 方法可以更新数据库的数据。例如: ``` $user = UserModel::where('id', 1)->find(); $user->name = 'John Smith'; $user->save(); ``` 可以使用 update() 方法更新多条数据。例如: ``` UserModel::where('age', '>', 18)->update(['is_adult' => true]); ``` 4. 删除数据 使用模型的 delete() 方法可以删除数据库的数据。例如: ``` $user = UserModel::where('id', 1)->find(); $user->delete(); ``` 可以使用 destroy() 方法删除多条数据。例如: ``` UserModel::where('age', '<', 18)->destroy(); ``` 以上是一些常见的 ThinkPHP 模型操作,你还可以使用其他高级操作,如聚合查询、关联查询等。具体可参考 ThinkPHP 的官方文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值