数据库快速入门:示例代码

以下页面包含示例代码,展示了如何使用数据库类。有关完整详细信息,请阅读描述每个函数的各个页面。

注意

CodeIgniter 不支持数据库、表和列名称中的点 (.)。

初始化数据库类

以下代码根据您的配置设置加载并初始化数据库类。

<?php

$db = \Config\Database::connect();

加载后,该类就可以像下面描述的那样使用。

注意

如果您的所有页面都需要数据库访问,您可以自动连接。有关详细信息,请参见连接页面。

标准查询,包含多个结果(对象版本)

<?php

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

foreach ($results as $row) {
    echo $row->title;
    echo $row->name;
    echo $row->email;
}

echo 'Total Results: ' . count($results);
上面的getResult()函数返回一个对象数组。
示例:$row->title

标准查询,包含多个结果(数组版本)

<?php

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

foreach ($results as $row) {
    echo $row['title'];
    echo $row['name'];
    echo $row['email'];
}
上面的getResultArray()函数返回一个标准数组索引的数组。
示例:$row['title']

标准查询,包含单个结果

<?php

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

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

标准查询,包含单个结果(数组版本)

<?php

$query = $db->query('SELECT name FROM my_table LIMIT 1');
$row   = $query->getRowArray();
echo $row['name'];

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

标准插入

<?php

$sql = 'INSERT INTO mytable (title, name) VALUES (' . $db->escape($title) . ', ' . $db->escape($name) . ')';
$db->query($sql);
echo $db->affectedRows();

查询构建器查询

查询构建器模式提供了一种简化的检索数据的方法。

<?php

$query = $db->table('table_name')->get();

foreach ($query->getResult() as $row) {
    echo $row->title;
}

上面的get()函数从提供的表中检索所有结果。查询构建器类包含用于处理数据的完整功能集。

查询构建器插入

<?php

$data = [
    'title' => $title,
    'name'  => $name,
    'date'  => $date,
];

$db->table('mytable')->insert($data);
// Produces: INSERT INTO mytable (title, name, date) VALUES ('{$title}', '{$name}', '{$date}')