深入理解CI框架的数据库操作技巧 (ci 数据库操作)

CI(Code Igniter)框架是一款轻量级、快速、简单易用的PHP框架,广受开发者的喜爱。在CI框架的数据库操作方面,提供了很多便捷的工具和技巧,本文将会深入剖析CI框架的数据库操作技巧,帮助大家更好的使用CI框架。

一、连接CI框架数据库

连接CI框架数据库需要在数据库配置文件database.php中配置连接信息。位于/config/database.php。在这个文件中,我们需要配置数据库连接和默认使用数据库,将以下配置改成自己的数据库信息。

“`php

$database[‘default’] = array(

‘dsn’ => ”,

‘hostname’ => ‘localhost’,

‘username’ => ‘root’,

‘password’ => ”,

‘database’ => ‘mydatabase’,

);

“`

配置完成后,我们就可以在控制器中使用以下代码来连接数据库了。

“`php

$this->load->database();

“`

如果您需要连接其他数据库, 可以使用以下命令

“`php

$DB2 = $this->load->database(‘otherdb’, TRUE);

“`

`otherdb`是数据库配置文件中的其中一个数据库项的名称。通过设置第二个参数为TRUE(布尔类型)来告诉CI你希望返回数据库对象,而不是默认的结果。

二、查询CI框架数据库

在CI框架的数据库查询方式中,提供了三种查询方法。分别是CI框架QueryBuilder类库、Active Record类和原生SQL语句。

1、QueryBuilder类库

QueryBuilder类库是CI框架查询的核心库,它提供了精简的API,是非常简单易读的查询方式。以下是一个QueryBuilder的使用示例:

“`php

$this->db->select(‘title, content, date’);

$this->db->from(‘mytable’);

$this->db->where(‘id’, $id);

$this->db->limit(10);

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

“`

上述代码通过调用select、from、where和limit等函数来组合生成一条SQL查询语句。CI框架将调用get函数,然后执行SQL查询,返回查询结果。

2、Active Record类

相比QueryBuilder类库,在Active Record类中,查询操作是更高级的方式。其API更加复杂,功能更加强大,比如支持多表连接查询。以下是Active Record类的使用示例:

“`php

$this->db->select(‘title, content, date’);

$this->db->from(‘mytable’);

$this->db->join(‘another_table’, ‘another_table.id = mytable.id’);

$this->db->where(‘id’, $id);

$this->db->where(‘date

$this->db->group_by(‘title’);

$this->db->limit(10);

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

“`

这段代码将生成一个包含多个条件限制(where、join、group_by)的Active Record查询语句。SQL查询由CI框架驱动器提供,并且结果将存储在结果数组中。这个Active Record类提供了很多快捷的查询方法,可以根据不同的业务需求快速完成查询逻辑。

3、原生SQL

原生SQL语句是最直接的框架查询方式。在CI框架中,可以使用query函数执行这样的查询,并返回查询结果集。

“`php

$query = $this->db->query(“SELECT `title` FROM `mytable` WHERE `id` = ‘1’”);

“`

在这个例子中直接使用SQL语句执行查询。

三、执行CI框架数据库的事务

CI框架提供了一个简单的事务处理方式,简单易懂。通过设置数据库主驱动器和事务处理脚本即可。以下是一个使用事务会话的代码示例:

“`php

$this->db->trans_start();

$this->db->query(‘AN SQL QUERY…’);

$this->db->query(‘ANOTHER QUERY…’);

$this->db->trans_complete();

“`

在这段代码中,我们使用 $this->db->trans_start() 开始事务,然后依次执行两个SQL语句,最后使用 $this->db->trans_complete() 结束事务。其中,如果事务执行失败,整个过程就会被回滚,来保证数据的一致性。

四、查询CI框架中的结果集

在使用CI框架的查询操作之后,得到的是一个查询结果集对象。有些情况下,我们需要从结果集对象中获取数据。这时可以使用CI框架的result()、result_array()、row()和row_array()函数。

1、result()

result()函数将结果集以对象的形式返回,这些对象具有与被查询表列名相同的属性。

“`php

$query = $this->db->query(“SELECT * FROM my_table”);

foreach ($query->result() as $row)

{

echo $row->title;

}

“`

通过前置循环,可以遍历并输出结果。

2、result_array()

与 result() 相关的函数是 result_array(),它以代表每一行记录的关联数组形式返回结果集。数组索引将对应的是表的列名。

“`php

$query = $this->db->query(“SELECT * FROM my_table”);

foreach ($query->result_array() as $row)

{

echo $row[‘title’];

}

“`

3、row()

row() 返回结果集中的单个行。如果你调用了该函数的多个次数,他返回的分别是结果集的各行行。

“`php

$query = $this->db->query(“SELECT * FROM my_table LIMIT 1”);

$row = $query->row();

echo $row->title;

“`

4、row_array()

row_array()函数以关联数组的形式返回的结果集中的单个行。如果你调用了该函数的多个次数,他返回的分别是结果集的各行行。

“`php

$query = $this->db->query(“SELECT * FROM my_table LIMIT 1”);

$row = $query->row_array();

echo $row[‘title’];

“`

五、设置, 更新和删除数据

在CI框架中, 除了查询操作, 还有对数据执行添加,更新,和删除操作。为了实现这些操作,CI框架提供了active record类库。该类提供了快捷的方法来设置,更新和删除数据。以下是一个简单的用法示例:

“`php

$data = array(

‘name’ => $name,

’eml’ => $eml,

‘url’ => $url,

);

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

“`

这个代码将在mytable表中插入名字、邮箱和 URL 数据。`insert()` 函数初始化一个 INSERT 查询,使用表示数据的关联数组填充数据。我们可以将其他数据类型添加到数据中以适应预期的表列类型。

以下示例中的代码将更新表中的数据:

“`php

$data = array(

‘name’ => $name,

’eml’ => $eml,

‘url’ => $url

);

$this->db->where(‘id’, $id);

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

“`

在这个例子中,我们通过调用 `update()` 函数,将id为 $id 的行的数据更新为 $data 数组中的值。update函数打开 UPDATE 查询,为运行中语句添加更新后的数据字段。同样,我们可以将其他数据类型添加到数组中以适应预期的列类型

删除操作和更新操作非常相似。您可以使用一般的向量和关联数组使用它:

“`php

$this->db->delete(‘mytable’, array(‘id’ => $id));

“`

这个代码将从mytable中删除 id 等于 $id 的行。

六、处理CI框架数据库的事务

在应用程序中,事务是处理的常见需求。事务可以确保在多个相关操作之间保持数据完整性和一致性。事务必须满足ACID属性:原子性、一致性、隔离性和持久性。

在CI框架中,事务可以使用如下方式开启、提交和回滚。

“`php

$this->db->trans_start();

// SQL 1

// SQL 2

$q1 = $this->db->query(‘YOUR QUERY HERE’);

$q2 = $this->db->query(‘YOUR QUERY HERE’);

$q3 = $this->db->query(‘YOUR QUERY HERE’);

$this->db->trans_complete();

“`

在这段代码中,我们在事务开始和结束之间给出每个 SQL 查询。如果事务无法成功进行,将回滚所有执行过的 SQL 查询。如果在事务内部的所有 SQL 查询都成功执行,那么 commit() 函数将被调用来提交事务。

在这个示例中,$q1、$q2 和 $q3 分别是输入语句的 SQL 查询对象。请注意,如果在提交时发生错误, 当前事务必须回滚。在任何情况下,建议使用 trans_complete 函数。

结语

通过本文的介绍,相信读者已经对CI框架的数据库操作有了更深入的了解。CI框架封装了复杂的数据库操作,方便我们的编程。在实际开发中,可以根据业务需求,选择合适的查询方式。同时,业务流程处理的过程中,需要始终关注数据一致性,使用事务协调各操作的执行,有效保证数据的正确性。CI框架是一个非常实用的框架,值得在项目中应用。


数据运维技术 » 深入理解CI框架的数据库操作技巧 (ci 数据库操作)