English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
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(发邮件时,请将#替换为@)进行举报,并提供相关证据,一经查实,本站将立即删除涉嫌侵权内容。