English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Concetti di sommario delle operazioni del database in Zend Framework

This article summarizes the database operations of Zend Framework. Share it with everyone for reference, as follows:

Zend_Db database knowledge

Example:

Model file:

$this->fetchAll("is_jian=1","id DESC",0,2)->toArray();
// According to is_jian=1, sort by id in descending order and take the first 2 records. If the first parameter is null, sort by id in descending order ASC is positive order.

Routing file:

$video = new Video(); // Instantiate the database class
$this->view->get2Video = $video->get2Video(); // Fetch 2 recommended data from the homepage

index.phtml file:

<?php foreach ($this->get2Video as $video): ?>
<?=$video['id']; ?>
<?=$video['name']; ?>
<? endforeach; ?>

Aggiungi virgolette per prevenire gli attacchi al database

Utilizzo di quote

$value = $db->quote('St John"s Wort');
// $value ora è '"St John\"s Wort"' (attenzione alle virgolette esterne)
// Aggiungi virgolette all'array
$value = $db->quote(array('a', 'b', 'c'));
// $value ora è '"a", "b", "c"' (separato da virgole)

Utilizzo di quoteInto

echo $where = $db->quoteInto('id = ?', 1);
// $where ora è 'id = "1"' (attenzione alle virgolette esterne)
// Aggiungi virgolette all'array nel where statement
$where = $db->quoteInto('id IN(?)', array(1, 2, 3));
// $where ora è 'id IN("1", "2", "3")' (una stringa separata da virgole)

(1) Sommario della query dei dati

Esegui direttamente la query. (Usa una query SQL completa)

//function quoteInto($text, $value, $type = null, $count = null)
$db = $this->getAdapter();
$sql = $db->quoteInto('SELECT * FROM `m_video` WHERE `is_guo` =?', '1');
$result = $db->query($sql);
// Utilizza l'oggetto PDOStatement $result per mettere tutti i dati dei risultati in un array
$videoArray = $result->fetchAll();

Utilizzo di fetchAll

fetchAll($where = null, $order = null, $count = null, $offset = null)

Recupera tutti i valori dei campi nella raccolta e li restituisce come array contiguo, se non viene impostato il parametro viene scritto come null

Può recuperare il numero specifico di risultati della raccolta.

$videoArray = $this->fetchAll("is_jian=1 and is_guo=1","id DESC",0,2)->toArray();

Uso di fetchAssoc

fetchAssoc($sql, $bind = array())

Ritorna tutti i valori dei campi del set di risultati, come array associativo, il primo campo come codice

$db = $this->getAdapter();
$videoArray=$db->fetchAssoc("SELECT * FROM m_video WHERE `is_jian` = :title",array('title' => '1'));

Uso di fetchCol

fetchCol($sql, $bind = array())

Ritorna il nome del primo campo di tutti i risultati

$db = $this->getAdapter();
$videoArray=$db->fetchCol("SELECT name FROM m_video WHERE `is_jian` = :title",array('title' => '1'));

Uso di fetchOne

fetchOne($sql, $bind = array())

Ritorna solo il valore del primo campo

$db = $this->getAdapter();
echo $videoArray=$db->fetchOne("SELECT count(*) FROM m_video WHERE `is_jian` = :title",array('title' => '1'));

Uso di fetchPairs

fetchPairs($sql, $bind = array())

Ritorna un array correlato, il valore del primo campo è il codice (id), il secondo campo è il valore (name)

Ritorna: Array( [1] => Il destino degli animali del calendario cinese [2] => Fortuna del fiori di pesco),1,2: sono i campi id.

$db = $this->getAdapter();
$videoArray=$db->fetchPairs("SELECT id, name FROM m_video WHERE is_jian = :title",array('title' => '1'));

Uso di fetchRow

fetchRow($where = null, $order = null)

Ritorna solo la prima riga del set di risultati

$videoArray=$this->fetchRow("is_jian=1 and is_guo=1", 'id DESC')->toArray();

Uso di query

//funzione query($sql, $bind = array())
$db = $this->getAdapter();
$result = $db->query('SELECT * FROM `m_video`');
// $result = $db->query('SELECT * FROM `m_video` WHERE `name` = ? AND id = ?',array('Il destino degli animali del calendario cinese', '1'));
// $result->setFetchMode(Zend_Db::FETCH_OBJ); // FETCH_OBJ è il valore predefinito, FETCH_NUM, FETCH_BOTH
// while ($row = $result->fetch()) {
// echo $row['name'];
// }
// $rows = $result->fetch();
// $rows = $result->fetchAll();
// $obj = $result->fetchObject(); // echo $obj->name;
// echo $Column = $result->fetchColumn(0); // Ottieni il primo campo del result set, ad esempio 0 è l'id, utilizzato per prendere solo un campo
print_r($rows);

Utilizzo di select

$db = $this->getAdapter();
$select = $db->select();
$select->from('m_video', array('id','name','clicks'))
->where('is_guo = :is_guo and name = :name')
->order('name') // Ordina per quale campo, partecipa come array (più campi) o stringa (un campo)
->group() // Raggruppa
->having() // Condizioni per la query di raggruppamento
->distinct() // Senza parametri, rimuovi i valori duplicati. A volte i risultati sono simili a quelli di groupby
->limit(10);
// Leggi i risultati utilizzando i parametri vincolati
$params = array('is_guo' => '1','name'=>'Il destino degli animali del calendario cinese');
// $sql = $select->__toString(); // Ottieni la query di ricerca, utile per il debug
$result = $db->fetchAll($select,$params);
Esegui la query di select
$stmt = $db->query($select);
$result = $stmt->fetchAll();

o usando}}

$stmt = $select->query();
$result = $stmt->fetchAll();

Se si utilizza direttamente

$db->fetchAll($select)

Risultati identici

Utilizzo query di ricerca congiunta tra tabelle multiple

$db = $this->getAdapter();
$select = $db->select();
$select->from('m_video', array('id','name','pic','actor','type_id','up_time'))
->where('is_guo = :is_guo and is_jian = :is_jian')
->order('up_time')
->limit(2);
$params = array('is_guo' => '1','is_jian'=>'1');
$select->join('m_type', 'm_video.type_id = m_type.t_id', 'type_name');// Query di ricerca congiunta tra tabelle multiple
$videoArray = $db->fetchAll($select,$params);

Il metodo find() può utilizzare il valore del chiave primaria per cercare dati nella tabella.

// SELECT * FROM round_table WHERE id = "1"
$row = $table->find(1);
// SELECT * FROM round_table WHERE id IN("1", "2", 3)
$rowset = $table->find(array(1, 2, 3));

(2) Sommario eliminazione dati

Primo metodo: può eliminare qualsiasi tabella

//quoteInto($text, $value, $type = null, $count = null)
$table = 'm_video';// Imposta la tabella che contiene i dati da eliminare
$db = $this->getAdapter();
$where = $db->quoteInto('name = ?', 'ccc');// Condizione WHERE per l'eliminazione dei dati
echo $rows_affected = $db->delete($table, $where);// Elimina i dati e ottieni il numero di righe influenzate

Secondo metodo: può solo eliminare la tabella corrente

//delete用法
// delete($where)
$where = "name = 'bbb'";
echo $this->delete($where);// 删除数据并得到影响的行数

(3)数据更新总结

第一种方法:可以更新任意表

// 以"列名"=>"数据"的格式构造更新数组,更新数据行
$table = 'm_video';// 更新的数据表
$db = $this->getAdapter();
$set = array (
'name' => '蝶影重重',
'clicks' => '888',
);
$where = $db->quoteInto('id = ?', '10');// where语句
// 更新表数据,返回更新的行数
echo $rows_affected = $db->update($table, $set, $where);

第二种方法:只能更新本表中的

$set = array (
'name' => '蝶影重重22',
'clicks' => '8880',
);
$db = $this->getAdapter();
$where = $db->quoteInto('id = ?', '10');// where语句
$rows_affected = $this->update($set, $where);// 更新表数据,返回更新的行数

(4)数据插入总结

第一种方法:可以在任意表中插入数据

$table = 'm_gao';// 插入数据的数据表
$db = $this->getAdapter();
// 以"列名"=>"数据"的格式构造插入数组,插入数据行
$row = array (
'title'   => '大家好。111',
'content' => '影视网要改成用zend framework开发啊',
'time' => '2009-05-04 17:23:36',
);
// 插入数据行并返回插入的行数
$rows_affected = $db->insert($table, $row);
// 最后插入的数据id
echo $last_insert_id = $db->lastInsertId();
$row=array(
'name'=>'curdate()',
'address' => new Zend_Db_Expr ('curdate()')
)

这样子字段name会插入一个curdate()的字符串,而address插入一个时间值(curdate()的结果2009-05-09)

第二种方法:只能适合本表中的还没有总结出来

(5)事务处理

$table = 'm_gao';// 插入数据的数据表
$db = $this->getAdapter();
$db->beginTransaction();//Zend_Db_Adapter会回到自动commit模式下,直到你再次调用beginTransaction()方法
// 以"列名"=>"数据"的格式构造插入数组,插入数据行
$row = array (
'id'=>null,
'title'   => '大家好。111',
'content' => '影视网要改成用zend framework开发啊',
'time' => '2009-05-04 17:23:36',
);
try {
// 插入数据行并返回插入的行数
$rows_affected = $db->insert($table, $row);
// 最后插入的数据id
$last_insert_id = $db->lastInsertId();
$db->commit(); // 事务提交
}catch (Exception $e){
$db->rollBack();
echo '捕获异常:'.$e->getMessage(); // 打印异常信息
}
echo $last_insert_id;

(6)其他

$db = $this->getAdapter();
$tables = $db->listTables(); //列出当前数据库中的所有表
$fields = $db->describeTable('m_video');//列出表的字段情况

更多关于zend相关内容感兴趣的读者可查看本站专题:《Zend FrameWork框架入门教程》、《php优秀开发框架总结》、《Yii框架入门及常用技巧总结》、《ThinkPHP入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家基于Zend Framework框架的PHP程序设计有所帮助。

声明:本文内容来自网络,版权属于原作者,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未进行人工编辑处理,也不承担相关法律责任。如果您发现涉嫌版权的内容,请发送邮件至:notice#oldtoolbag.com(发邮件时,请将#替换为@)进行举报,并提供相关证据,一经查实,本站将立即删除涉嫌侵权内容。

Ti potrebbe interessare