数据库快速入门:示例代码
以下页面包含示例代码,展示了如何使用数据库类。有关完整详细信息,请阅读描述每个函数的各个页面。
注意
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}')