CodeIgniter - 数据库的增删改查

简介: 数据库操作无非是CRUD,用非装逼的语言来说就是增删改查。也许这一节会讲的很泛泛,或者很多人看不懂,没关系,大致的看看,知道是这么回事就好,继续往后看,后面会讲实例,这些枯燥而又抽象的东西可以先跳过,慢慢就会明白了。

数据库操作无非是CRUD,用非装逼的语言来说就是增删改查。也许这一节会讲的很泛泛,或者很多人看不懂,没关系,大致的看看,知道是这么回事就好,继续往后看,后面会讲实例,这些枯燥而又抽象的东西可以先跳过,慢慢就会明白了。而且这部分内容CI手册讲的很全面,我也没什么好方式讲的很通俗易懂,索性不重复造那么大的轮子。

 

 

连接数据库

 

想要操作数据库,首先要确认已经配置好数据库连接设置,这点在安装部分的最下面已经讲过,不再重复。

虽然配置好了,但是文件如何加载此类配置?在相应的控制器或者模型里对应的位置添加

$this->load->database();

一般是在模型的构造函数里添加此代码,这样只要调用了该模型,所有控制器和该模型内的其他函数都可以连接数据库。

如果你不知道什么是控制器、模型等,请按我如下操作:

打开 application/models 文件夹新建一个文件 model.php,代码如下:

<?php

class Model extends CI_Model {

  public function __construct()

  {

    $this->load->database();

  }

}

 

 

读取数据库内容

 

以上连接数据库的操作都设置好之后,我们就可以来利用CI自带的Active Record模式 来读取数据库内容了。

$query = $this->db->get('news');

return $query->result_array();

get()是用来获取数据库里指定表的内容,没加限定的where之类的,就是获取所有内容。

result_array()意思为返回数组形式的结果集,不加array就是返回对象形式的,更详细的可以参见 Active Record 类 这里不做过多详解。

return是函数内用来返回结果的操作,也可以赋值、var_dump 等之类操作查看$query->result_array();的内容

 

我一般习惯这样写,比较懒省事:

$query = $this->db->get('news')->result_array();

return $query;

看个人使用喜好了。

 

 

插入新数据内容

 

可以用数组的形式通过$this->db->insert()插入数据,第一个参数为插入数据的表名,第二个参数为数组,键名对应数据表字段名,后面是数据。

$data = array(

               'title' => 'My title' ,

               'name' => 'My Name' ,

               'date' => 'My date'

            );

$this->db->insert('mytable', $data); 

 

将执行如下SQL语句: INSERT INTO mytable (title, name, date) VALUES ('My title', 'My name', 'My date')

这样写起来是不是比直接写sql来的要简明的多?

 

 

更新数据内容

 

$data = array(

               'title' => $title,

               'name' => $name,

               'date' => $date

            );

$this->db->where('id', $id);

$this->db->update('mytable', $data);

生成:

UPDATE mytable 

SET title = '{$title}', name = '{$name}', date = '{$date}'

WHERE id = $id

和插入的代码相比,就多了一个where条件,更新特定条目,不加where就更新所有表内内容了。虽然where和update不在同一行,但是一串数据库的操作会排在一起执行的,这个不用担心。

 

 

删除数据内容

 

$this->db->where('id', $id);

$this->db->delete('mytable'); 

生成:

DELETE FROM mytable 

WHERE id = $id

这里和上面的更新类似,只是加了where条件,没有数组传入。

这样就是基本的数据库增删改查操作,这里只是大致的讲了下,没详细的讲解,以后有时间慢慢完善吧,大家可以参见 Active Record 类

如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
目录
相关文章
|
11天前
|
SQL 关系型数据库 API
HarmonyOs开发:关系型数据库封装之增删改查
每个方法都预留了多种调用方式,比如使用callback异步回调或者使用Promise异步回调,亦或者同步执行,大家在使用的过程中,可以根据自身业务需要进行选择性调用,也分别暴露了成功和失败的方法,可以针对性的判断在执行的过程中是否执行成功。
74 13
|
3月前
|
前端开发 Java 数据库连接
javamvc配置,增删改查,文件上传下载。
【10月更文挑战第4天】javamvc配置,增删改查,文件上传下载。
43 1
|
3月前
|
存储 NoSQL API
使用Py2neo进行Neo4j图数据库的增删改查操作
使用Py2neo进行Neo4j图数据库的增删改查操作
140 5
|
3月前
|
数据可视化 API PHP
低代码开发工具-学生管理系统-老师管理增删改查实现
低代码开发工具-学生管理系统-老师管理增删改查实现
52 5
|
4月前
|
SQL 关系型数据库 MySQL
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
课程分类查询、课程新增、统一异常处理、统一封装结果类、JSR303校验、修改课程、查询课程计划、新增/修改课程计划
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
|
3月前
|
JavaScript 前端开发 测试技术
[新手入门]todolist增删改查:vue3+ts版本!
【10月更文挑战第15天】[新手入门]todolist增删改查:vue3+ts版本!
|
4月前
|
SQL 关系型数据库 MySQL
ThinkPHP6 连接使用数据库,增删改查,find,select,save,insert,insertAll,insertGetId,delete,update方法的用法
本文介绍了在ThinkPHP6框架中如何连接和使用数据库进行增删改查操作。内容包括配置数据库连接信息、使用Db类进行原生MySQL查询、find方法查询单个数据、select方法查询数据集、save方法添加数据、insertAll方法批量添加数据、insertGetId方法添加数据并返回自增主键、delete方法删除数据和update方法更新数据。此外,还说明了如何通过数据库配置文件进行数据库连接信息的配置,并强调了在使用Db类时需要先将其引入。
ThinkPHP6 连接使用数据库,增删改查,find,select,save,insert,insertAll,insertGetId,delete,update方法的用法
|
3月前
|
Java API 数据库
Data jpa 增删改查的方法分别有哪些
Data jpa 增删改查的方法分别有哪些
|
5月前
|
SQL 数据库连接 API
ThinkPHP6实现增删改查接口
ThinkPHP6实现增删改查接口
60 1
|
5月前
|
XML 数据库 数据格式
Spring5入门到实战------14、完全注解开发形式 ----JdbcTemplate操作数据库(增删改查、批量增删改)。具体代码+讲解 【终结篇】
这篇文章是Spring5框架的实战教程的终结篇,介绍了如何使用注解而非XML配置文件来实现JdbcTemplate的数据库操作,包括增删改查和批量操作,通过创建配置类来注入数据库连接池和JdbcTemplate对象,并展示了完全注解开发形式的项目结构和代码实现。
Spring5入门到实战------14、完全注解开发形式 ----JdbcTemplate操作数据库(增删改查、批量增删改)。具体代码+讲解 【终结篇】