在 CodeIgniter 中,使用数据库是非常频繁的事情。你可以使用框架自带的数据库类,就能便捷地进行数据库操作。

  初始化数据库类

  依据你的数据库配置载入并初始化数据库类:

  $this->load->database();

  被载入之后你可以在任何地方使用它。

  以对象形式返回查询结果

  $query = $this->db->query('SELECT name, title, email FROM my_table');

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

  {

  echo $row->title;

  echo $row->name;

  echo $row->email;

  }

  echo 'Total Results: ' . $query->num_rows();

  上面的result()函数返回一个对象的数组。例如:$row->title

  以数组形式返回查询结果

  $query = $this->db->query('SELECT name, title, email FROM my_table');

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

  {

  echo $row['title'];

  echo $row['name'];

  echo $row['email'];

  }

  上面的result_array()函数返回一个带下标的数组。例如:$row['title']

  返回一条数据

  对象形式:

  $query = $this->db->query('SELECT name FROM my_table LIMIT 1');

  $row = $query->row();

  echo $row->name;

  上面的row()函数返回一个 对象。例如:$row->name

  数组形式:

  $query = $this->db->query('SELECT name FROM my_table LIMIT 1');

  $row = $query->row_array();

  echo $row['name'];

  上面的row_array()函数返回一个 数组。例如:$row['name']

  插入(insert)数据

  $sql = "INSERT INTO mytable (title, name)

  VALUES (".$this->db->escape($title).", ".$this->db->escape($name).")";

  $this->db->query($sql);

  echo $this->db->affected_rows();

  快捷插入方式:

  $data = array(

  'title' => $title,

  'name' => $name,

  'date' => $date

  );

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

  // Produces: INSERT INTO mytable (title, name, date) VALUES ('{$title}', '{$name}', '{$date}')

  数据库配置

  CodeIgniter 有一个配置文件让你存放数据库连接值(username:用户名,password:密码,database name:数据库名,等等..). 配置文件位于以下路径:application/config/database.php

  配件文件存放在一个如下格式的一个多维数组里:

  $db['default']['hostname'] = "localhost";

  $db['default']['username'] = "root";

  $db['default']['password'] = "";

  $db['default']['database'] = "database_name";

  $db['default']['dbdriver'] = "mysql";

  $db['default']['dbprefix'] = "";

  $db['default']['pconnect'] = TRUE;

  $db['default']['db_debug'] = FALSE;

  $db['default']['cache_on'] = FALSE;

  $db['default']['cachedir'] = "";

  $db['default']['char_set'] = "utf8";

  $db['default']['dbcollat'] = "utf8_general_ci";

  使用多维数组的原因是为了让你随意的存储多个连接值的设置。举例:如果你运行多个环境(development:开发、production:制作、test:测试 等等..),你能为每个环境建立独立的连接组,并在组直接进行切换。举例,设置一个"test"环境,你可以这样做:

  $db['test']['hostname'] = "localhost";

  $db['test']['username'] = "root";

  $db['test']['password'] = "";

  $db['test']['database'] = "database_name";

  $db['test']['dbdriver'] = "mysql";

  $db['test']['dbprefix'] = "";

  $db['test']['pconnect'] = TRUE;

  $db['test']['db_debug'] = FALSE;

  $db['test']['cache_on'] = FALSE;

  $db['test']['cachedir'] = "";

  $db['test']['char_set'] = "utf8";

  $db['test']['dbcollat'] = "utf8_general_ci";

  那么,告诉系统使用"test"组,你可以设置位于配置文件中的变量:

  $active_group = "test";

  注意: "test"的名字是任意的,这可以让你自由设置,我们的主要连接默认使用"default"这个名字,当然,您可以基于您的项目为它起一个更有意义的名字。

  Active Record

  Active Record 类 可以通过数据库配置文件里的$active_record变量进行全局的设定(允许/禁止 TRUE/FALSE (boolean)). 如果你不用这个类,哪么你可以通过将这个变量值设置成FALSE来减少在数据库类初始化时对电脑资源的消耗。 $active_record = TRUE;

  注意: 一些CodeIgniter的类,例如Sessions,在执行一些函数的时候需要Active Records的支持。

  参数解析:

  hostname - 数据库的主机名,通常位于本机,可以表示为 "localhost".

  username - 需要连接到数据库的用户名.

  password - 登陆数据库的密码.

  database - 你需要连接的数据库名.

  dbdriver - 数据库类型。如:mysql、postgres、odbc 等。必须为小写字母。

  dbprefix - 当运行Active Record查询时数据表的前缀,它允许在一个数据库上安装多个CodeIgniter程序.

  pconnect - TRUE/FALSE (boolean) - 使用持续连接.

  db_debug - TRUE/FALSE (boolean) - 显示数据库错误信息.

  cache_on - TRUE/FALSE (boolean) - 数据库查询缓存是否开启,详情请见数据库缓存类。

  cachedir - 数据库查询缓存目录所在的服务器绝对路径。

  char_set - 与数据库通信时所使用的字符集。

  dbcollat - 与数据库通信时所使用的字符规则(character collation )。

  port - 数据库端口号. 当前只用于 Postgres 驱动程序. 要使用这个值,你应该添加一行代码到数据库配置数组。

  记录一下,方便查阅。文章转载自 [http://www.php230.com]

  (编辑:雷林鹏 来源:网络 侵删)

雷林鹏分享:CodeIgniter常用的数据库操作类的更多相关文章

  1. 循序渐进学.Net Core Web Api开发系列【9】:常用的数据库操作

    系列目录 循序渐进学.Net Core Web Api开发系列目录 本系列涉及到的源码下载地址:https://github.com/seabluescn/Blog_WebApi 一.概述 本篇描述一 ...

  2. 高级运维(六):源码安装Redis缓存服务、常用Redis数据库操作指令、配置Redis主从服务器

    一.源码安装Redis缓存服务 目标: 本案例要求先快速搭建好一台Redis服务器,并测试该缓存服务器: 1> 设置变量test,值为123 2> 查看变量test的值 3> 设置计 ...

  3. 【知识必备】ezSQL,最好用的数据库操作类,让php操作sql更简单~

    最近用php做了点小东东,用上了ezSQL,感觉真的很ez,所以拿来跟大家分享一下~ ezSQL是一个非常好用的PHP数据库操作类.著名的开源博客WordPress的数据库操作就使用了ezSQL的My ...

  4. php : mysql数据库操作类演示

    设计目标: 1,该类一实例化,就可以自动连接上mysql数据库: 2,该类可以单独去设定要使用的连接编码(set names XXX) 3,该类可以单独去设定要使用的数据库(use XXX): 4,可 ...

  5. 一个基于PDO的数据库操作类(新) 一个PDO事务实例

    <?php /* * 作者:胡睿 * 日期:2011/03/19 * 电邮:hooray0905@foxmail.com * * 20110319 * 常用数据库操作,如:增删改查,获取单条记录 ...

  6. C# Oracle数据库操作类实例详解

    本文所述为C#实现的Oracle数据库操作类,可执行超多常用的Oracle数据库操作,包含了基础数据库连接.关闭连接.输出记录集.执行Sql语句,返回带分页功能的dataset .取表里字段的类型和长 ...

  7. 扣出thinkphp数据库操作类

    假如你是一位thinkphp的使用者,想必你会觉得thinkphp操作数据库非常方便.现在在你面前有一个非常小的作业,小到完全没有必要用thinkphp去完成它.但是你又觉得不用thinkphp的话, ...

  8. Android打造属于自己的数据库操作类。

    1.概述 开发Android的同学都知道sdk已经为我们提供了一个SQLiteOpenHelper类来创建和管理SQLite数据库,通过写一个子类去继承它,就可以方便的创建.管理数据库.但是当我们需要 ...

  9. PHP 数据库操作类:ezSQL

    EZSQL类介绍: 下载地址:http://www.jb51.net/codes/26393.htmlezsql是一个小型的快速的数据库操作类,可以让你很容易地用PHP操作各种数据库( MySQL.o ...

随机推荐

  1. mysql 处理utf8mb4的问题

    jdbc端的characterEncoding=utf8 无法改为utf8mb4 测试: create table utf8mb4_test (name1 varCHAR(20) CHARACTER ...

  2. 23.C# 语言的改进

    1.对象初始化器 class Curry { public string MainIngredient{get;set;} public string Style { get; set; } publ ...

  3. Google word/sheets 常见的使用:

    Google Sheets: 1, sheets 里面的单元格设置自动换行: 选中单元格: --> Format --> Text Wrapping --> Wrap(自动换行)/C ...

  4. Python:re中的group方法简介

    原文地址:http://www.cnblogs.com/kaituorensheng/archive/2012/08/20/2648209.html. 正则表达式中,group()用来提出分组截获的字 ...

  5. js数组创建两种方法

    一.数组直接量形式创建数组 var arr=[];//空数组 ,,,,,]; ,,,],{x:,y:}]; ; ,x+,x+]; console.log(arr3); //[1,3,3,4] ,,]; ...

  6. mac & ip

    mac 解决本地网络机器的通信 ip 解决不同网络间主机的通信

  7. Rman常用命令

    配置基于时间的备份保留策略 RMAN> CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 7 DAYS; 恢复spfile RMAN> re ...

  8. git cherry-pick 的使用

    之前和同事在不同的分支开发一个功能的不同模块,在自己分支有用到同事分支的一些实现,被老大告诉用git cherry-pick来搞定! git cherry-pick  能够把另一个分支的一个或多个提交 ...

  9. kbmmemtable sorton 报错 : List index out of bounds

    同一数据集,不同的排序条件,有的可以,但某一条件,却能100%重现报错. procedure TkbmIndex.InternalFastQuickSort(const L,R:Integer); v ...

  10. 算法(第四版)C# 习题题解——2.5

    写在前面 整个项目都托管在了 Github 上:https://github.com/ikesnowy/Algorithms-4th-Edition-in-Csharp 查找更方便的版本见:https ...