您现在的位置: 万盛学电脑网 >> 程序编程 >> 网络编程 >> php编程 >> 正文

Drupal7中常用的数据库操作实例

作者:佚名    责任编辑:admin    更新时间:    2015-10-15 09:00:22

 Drupal 7 提供的新功能其中一个就是可以使用 Query Builder and Query Objects 查询生成器来构造查询对象的能力,无需在代码中写原始的SQL语句,一是提高了代码可阅读性,二是兼容所有数据库

1.插入单条记录   代码如下:db_insert("table")->fields(array('field1' => 'value1', 'field2' => 'value2', 'fieldn' => $valuen))->execute();   2.插入多条记录    代码如下:$values[] = array('field1' => 'val1', 'field2' => 'val2', 'fieldn' => $valn); $values[] = array('field1' => 'value1', 'field2' => 'value2', 'fieldn' => $valuen); $query = db_insert(‘table')->fields(array('field1', 'field2', 'fieldn')); foreach ($values as $record) {    $query->values($record); } $query->execute();   3.更新某条记录 代码如下:db_update('imports')    ->condition('name', 'Chico')    ->fields(array('address' => 'Go West St.'))    ->execute(); //等同于:   UPDATE {imports} SET address = 'Go West St.' WHERE name = 'Chico';   4.删除某条记录    代码如下:db_delete('imports')    ->condition('name' => 'Zeppo')    ->execute(); 5.合并记录    代码如下:db_merge('people')   ->key(array('job' => 'Speaker'))   ->insertFields(array('age' => 31,'name' => 'Meredith'))   ->updateFields(array('name' => 'Tiffany'))   ->execute(); //如果存在job为Speaker的一条记录,则更新name为Tiffany,如果不存在,就插入一条age为31,name为Meredith,job为Speaker的记录。     6.对数据库某字段值自动加一或者自增。   代码如下:db_update('example_table')   ->expression('count', 'count + 1')   ->condition('field1', $some_value)   ->expression('field2', 'field2 + :inc', array(':inc' => 2))   ->execute();   7.查询数据库某字段为另一别名(alias)    代码如下:$query = db_select('node', 'n'); $query->addField('n', 'name', 'label'); $query->addField('n', 'name', 'value');