第一篇:數(shù)據(jù)庫操作
Excel技巧:Excel如何快速統(tǒng)計(jì)各銷售人員的銷售總金額?
繼續(xù)解決Q群小伙伴提出的問題,Excel如何快速統(tǒng)計(jì)各銷售人員的銷售總金額?題目問得好像是個(gè)銷售問題,其實(shí)針對各種分類匯總的數(shù)據(jù)統(tǒng)計(jì)。這次用透視表的方法給大家分享一下快速統(tǒng)計(jì)的方法。
場景:適合財(cái)務(wù)、銷售、HR等數(shù)據(jù)統(tǒng)計(jì)的辦公人士。問題:Excel如何快速統(tǒng)計(jì)各銷售人員的銷售總金額? 解答:利用Excel的數(shù)據(jù)透視表搞定!
具體操作如下:將光標(biāo)放置于銷售人員銷售表格區(qū)域中任意單元格,然后再插入選項(xiàng)卡中點(diǎn)擊“數(shù)據(jù)透視表”功能。
第二篇:操作數(shù)據(jù)庫小結(jié)
一.查詢操作
對數(shù)據(jù)進(jìn)行查詢操作時(shí),有兩種情況:一是查詢單個(gè)值,二是 查詢?nèi)舾蓷l記錄。
1、查詢單個(gè)值
需要使用Command對象的ExecuteScalar()方法:步驟如下:(1)、創(chuàng)建Connection對象(數(shù)據(jù)庫連接對象)。(2)、創(chuàng)建查詢用的SQL語句。(3)、利用SQL語句和Connection對象創(chuàng)建Command對象。(4)、打開數(shù)據(jù)庫連接,調(diào)用Connection對象的Open()方法。(5)、調(diào)用Command對象的ExecuteScalar()方法,返回一個(gè)標(biāo)量值。(6)、操作完成后關(guān)閉數(shù)據(jù)庫連接,調(diào)用Connection對象的Close()方法。
2、查詢?nèi)舾蓷l記錄
需要使用Command對象的ExecuteReader()方法:步驟如下:(1)、創(chuàng)建Connection對象(數(shù)據(jù)庫連接對象)。(2)、創(chuàng)建查詢用的SQL語句。(3)、利用SQL語句和Connection對象創(chuàng)建Command對象。(4)、打開數(shù)據(jù)庫連接,調(diào)用Connection對象的Open()方法。(5)、調(diào)用Command對象的ExecuteReader()方法,返回一個(gè)DataReader對象。(6)、調(diào)用DataReader對象的Read()方法逐行讀取記錄,如果讀到記錄返回Ture,否則返回False.(7)、使用(type)dataReader[列名或索引]的方式讀取這一行中某一列的值。(8)、關(guān)閉DataReader對象(9)、操作完成后關(guān)閉數(shù)據(jù)路連接,調(diào)用Connection對象的Close()方法。
二、非查詢操作
對數(shù)據(jù)庫執(zhí)行非查詢操作時(shí),包括增加,修改,刪除數(shù)據(jù),都使用Command對象的ExecuteNonQuery()方法,步驟如下:
(1)、創(chuàng)建Connection對象(數(shù)據(jù)庫連接對象)(2)、創(chuàng)建增刪改用的SQL語句。(3)、利用SQL語句和Connection對象創(chuàng)建Command對象。(4)、打開數(shù)據(jù)庫連接,調(diào)用Connection對象的Open()方法。(5)、調(diào)用Command對象的ExecuteNonQuery()方法執(zhí)行命令,返回受影響的行數(shù)。(6)、操作完成后關(guān)閉數(shù)據(jù)庫連接,調(diào)用Connection對象的Close()方法。
本章總結(jié)
1、使用DataReader查詢數(shù)據(jù)記錄,通過Command對象的ExecuteReader()方法返回一個(gè)DataReader對象。
2、使用DataReader讀取數(shù)據(jù)室每次調(diào)用Read()方法讀取一行數(shù)據(jù)。
3、DataReader使用完后要調(diào)用它的Close()方法關(guān)閉。
4、使用Command對象的ExecuteNonQuery()方法對數(shù)據(jù)進(jìn)行增刪改的操作。
5、ExecuteNonQuery()方法返回受影響的行數(shù)。
6、ListView(列表視圖)控件有5種視圖模式,重點(diǎn)是Details 列表視圖的Items屬性表示包含在空間中的所有項(xiàng)的結(jié)合,每一個(gè)項(xiàng)都是一個(gè)ListViewItem,使用Items.Add()方法向列表視圖中添加一項(xiàng) 調(diào)用列表視圖項(xiàng)的SubItems.AddRange()方法添加它的子項(xiàng)
ListViewItem lviStudent = new ListViewItem(loginID);創(chuàng)建一個(gè)ListView項(xiàng) lviStudent.Tag=(int)dataReader[“StudentId”];lvStudent.Items.Add(lviStudent);//向ListView中添加一個(gè)新項(xiàng) lviStudent.SubItems.AddRange(new string[] {studentName,studentNo,userState});//向當(dāng)前項(xiàng)中添加子項(xiàng)
7、ContextMenuStrip(快捷菜單)控件可以與其他控件結(jié)合使用,通過設(shè)置控件的ContextMenuStrip屬性來指定它的快捷菜單。
想鼠標(biāo)右鍵單擊文本框時(shí)出現(xiàn)快捷菜單,就選中文本框?在屬性窗口中找到它的ContextMenuStrip屬性,選擇已有的右鍵菜單控件 txtLoginId.Focus():?
下拉列表:
創(chuàng)建Command對象?調(diào)用Command對象的ExecuteReader()方法創(chuàng)建DataReader對象(sqlDataReader dataReader=command.ExecuteReader())?使用DataReader的Reader()方法逐行讀取數(shù)據(jù)(放回bool類型)?讀取當(dāng)前行的某列的數(shù)據(jù)(cboGrade.Items.Add(dataReader[“列名”]))?關(guān)閉DataReader對象,Close()方法
向數(shù)據(jù)庫中添加數(shù)據(jù):
創(chuàng)建Connection對象?定義要執(zhí)行的SQL語句?創(chuàng)建Command對象?執(zhí)行ExecuteNonQuery()方法?根據(jù)返回的結(jié)果進(jìn)行后續(xù)的處理
雙擊顯示出ID:
MessageBox.show(dataGridView1.SelectedRows[0].cells[“ColID”].value.ToString());
刷新:
1,BindStudentByLoginID(txtBox.Text)2,listView.Items.RemoveAt(Listview1.SelectedIndices[0])//只能刪除選中的行(選中第幾個(gè))
第三篇:數(shù)據(jù)庫操作文檔實(shí)踐總結(jié)
Oracle導(dǎo)入操作
1、點(diǎn)擊服務(wù)器開始菜單選擇運(yùn)行,輸入CMD后回車打開命令輸入框
2、輸入命令imp
3、根據(jù)提示輸入要導(dǎo)入的oracle用戶和口令(用戶名:rmp_jms 口令:1)
4、根據(jù)提示輸入要導(dǎo)入數(shù)據(jù)文件如)rmpjms2012908.dmp
5、根據(jù)提示輸入緩存大小 回車
6、提示只列出導(dǎo)入文件內(nèi)容 no 回車
7、忽略創(chuàng)建錯(cuò)誤 yes 回車
8、導(dǎo)入權(quán)限 no 回車
9、導(dǎo)入數(shù)據(jù) yes 回車
10、導(dǎo)入整個(gè)文件 yes 回車
Oracle導(dǎo)出命令
1、運(yùn)行cmd進(jìn)入dos窗口
2、輸入命令exp
3、根據(jù)提示輸入要導(dǎo)入的oracle用戶和口令(用戶:rmp_jms 口令:1)
4、根據(jù)提示輸入緩沖大小 回車
f:...(例
5、根據(jù)提示輸入要導(dǎo)出數(shù)據(jù)存放位置文件名(例如)f:...rmpjms20120908.dmp
6、根據(jù)提示選擇1.完整的數(shù)據(jù)庫2.用戶(U)3.表(T)用戶(U)
回車
7、是否導(dǎo)出權(quán)限 no 回車
8、導(dǎo)出表數(shù)據(jù) yes 回車
9、壓縮區(qū) yes 回車
10、要導(dǎo)出的用戶:rmp_jms 回車
11、要導(dǎo)出的用戶: 直接回車
第四篇:SQLCE數(shù)據(jù)庫操作總結(jié)
創(chuàng)建新的數(shù)據(jù)庫
SQL Server CE 中的數(shù)據(jù)庫是存儲結(jié)構(gòu)化數(shù)據(jù)的表集合。在可以存儲數(shù)據(jù)庫之前,必須創(chuàng)建數(shù)據(jù)庫。在創(chuàng)建數(shù)據(jù)庫之后,可以創(chuàng)建保存數(shù)據(jù)的表。
在本節(jié)中,您將創(chuàng)建一個(gè)新的數(shù)據(jù)庫,然后創(chuàng)建一個(gè)表,最后將數(shù)據(jù)添加到該表中。若要執(zhí)行這些步驟,請使用 SQL Server CE(System.Data.SqlServerCe).NET Framework 精簡版數(shù)據(jù)提供程序的 SqlCeConnection、SqlCeEngine 和 SqlCeCommand 類。
注意 不能在此任務(wù)中運(yùn)行僅用于特定步驟的代碼。有關(guān)完整代碼列表,請參見代碼列表:使用 SQL Server CE 數(shù)據(jù)庫。
創(chuàng)建新的 SQL Server CE 數(shù)據(jù)庫
1.啟動(dòng) Visual Studio.NET,然后打開一個(gè)新項(xiàng)目。
2.創(chuàng)建對使用的命名空間的引用。
using System;using System.IO;using System.Text;using System.Data;using System.Data.SqlServerCe;using System.Collections;using System.Windows.Forms;using System.Data.Common;3.創(chuàng)建 WalkThrough 類。
public class WalkThrough {
static void Main()
{
SqlCeConnection conn = null;
try
{ 4.驗(yàn)證具有您打算使用的名稱的數(shù)據(jù)庫是否已存在。
if(File.Exists(“Test.sdf”))
File.Delete(“Test.sdf”);5.使用 System.Data.SqlCeEngine 對象創(chuàng)建名為 Test.sdf 的空數(shù)據(jù)庫。
注意 SQL Server CE 中,數(shù)據(jù)庫名稱的文件擴(kuò)展名為.sdf。
SqlCeEngine engine = new SqlCeEngine(“Data Source = Test.sdf”);
engine.CreateDatabase();6.連接到這個(gè)新數(shù)據(jù)庫。
conn = new SqlCeConnection(“Data Source = Test.sdf”);conn.Open();創(chuàng)建新表
1.使用 System.Data.SqlCeCommand 創(chuàng)建命令類的實(shí)例。
SqlCeCommand cmd = conn.CreateCommand();2.運(yùn)行命令 cmd 創(chuàng)建表。用于創(chuàng)建表的指令必須在 cmd.CommandText 所包含的 SQL 代碼中。
若要使用 SQL Server CE 的 SQL 編程語言創(chuàng)建表,請使用 CREATE TABLE 語法。有關(guān)更多信息,請參見《SQL Server CE 聯(lián)機(jī)手冊》中的用于 SQL Server CE 的 SQL 參考。
cmd.CommandText = “CREATE TABLE TestTbl(col1 int PRIMARY KEY, col2 ntext, col3 money)”;cmd.ExecuteNonQuery();將數(shù)據(jù)添加到新表中
1.運(yùn)行命令以添加數(shù)據(jù)行。與創(chuàng)建表相同,用于添加行的指令也必須在 cmd.CommandText
所包含的 SQL 代碼中。若要使用 SQL Server CE 的 SQL 編程語言將行添加到表中,請使用 INSERT 語法。有關(guān)更多信息,請參見《SQL Server CE 聯(lián)機(jī)手冊》中的用于 SQL Server CE 的 SQL 參考。
cmd.CommandText = “INSERT INTO TestTbl(col1, col2, col3)VALUES(0, 'abc', 15.66)”;cmd.ExecuteNonQuery();2.創(chuàng)建命令,使用參數(shù)將數(shù)據(jù)多次插入表中。
參數(shù)可以更高效地查詢數(shù)據(jù)庫,因?yàn)榭梢允褂靡唤M包含參數(shù)的 SQL 語句插入多個(gè)值。有關(guān)更多信息,請參見《SQL Server CE 聯(lián)機(jī)手冊》的在查詢中使用參數(shù)。
cmd.CommandText = “INSERT INTO TestTbl(col1, col2, col3)VALUES(?, ?, ?)”;
cmd.Parameters.Add(new SqlCeParameter(“p1”, SqlDbType.Int));cmd.Parameters.Add(new SqlCeParameter(“p2”, SqlDbType.NText));cmd.Parameters.Add(new SqlCeParameter(“p3”, SqlDbType.Money));
cmd.Parameters[“p2”].Size = 50;
cmd.Prepare();3.執(zhí)行參數(shù)化命令,將數(shù)據(jù)插入表中。
cmd.Parameters[“p1”].Value = 1;cmd.Parameters[“p2”].Value = “abc”;cmd.Parameters[“p3”].Value = 15.66;cmd.ExecuteNonQuery();4.清除參數(shù),并檢查已插入表中的數(shù)據(jù)。
若要使用 SQL Server CE 的 SQL 編程語言讀取現(xiàn)有數(shù)據(jù),請使用 SELECT 語法。有關(guān)更多信息,請參見《SQL Server CE 聯(lián)機(jī)手冊》中的用于 SQL Server CE 的 SQL 參考。
cmd.Parameters.Clear();//Set the command text to a SELECT query.// cmd.CommandText = “SELECT * FROM TestTbl”;讀取 SQL Server CE 數(shù)據(jù)庫數(shù)據(jù)
讀取數(shù)據(jù)庫數(shù)據(jù)是一種常見的任務(wù),通常涉及對表行信息的訪問。為使用
System.Data.SqlServerCe 執(zhí)行此任務(wù),您需要 SqlCeDataReader 和 SqlCeCommand 對象。注意 有關(guān)完整代碼列表,請參見代碼列表:使用 SQL Server CE 數(shù)據(jù)庫。
1.調(diào)用 SqlCeCommand 對象的 ExecuteReader 方法以創(chuàng)建 SqlCeDataReader 的實(shí)例。
SqlCeDataReader rdr = cmd.ExecuteReader();2.指示數(shù)據(jù)讀取器 rdr 在行存在時(shí)在每行的列中顯示數(shù)據(jù)。
while(rdr.Read()){MessageBox.Show(“col1 = ” + rdr.GetInt32(0)+
“col2 = ” + rdr.GetString(1)+
“col3 = ” + rdr.GetSqlMoney(2));} 更改 SQL Server CE 數(shù)據(jù)庫中的數(shù)據(jù)
在創(chuàng)建表后,可以以多種方式修改表中的數(shù)據(jù):更改特定數(shù)據(jù)的屬性,添加和刪除數(shù)據(jù)行,甚至還可以通過修改表中的列來更改存儲數(shù)據(jù)的方式。
在本節(jié)中,您將更改表項(xiàng)的值,查找更改的表的數(shù)據(jù)并處理所有錯(cuò)誤。為執(zhí)行這些步驟,您將使用在前面的任務(wù)中使用的類:SqlCeCommand 和 SqlCeDataReader。另外,您將使用 SqlCeException 進(jìn)行錯(cuò)誤處理。
注意 不能在此任務(wù)中運(yùn)行僅用于特定步驟的代碼。有關(guān)完整代碼列表,請參見代碼列表:使用 SQL Server CE 數(shù)據(jù)庫。
更新 SQL Server CE 表中的數(shù)據(jù)
? 設(shè)置命令對象以使用 UPDATE 語句。
若要使用 SQL Server CE 的 SQL 編程語言更改行列的值,請使用 UPDATE 語法。有關(guān)更多信息,請參見《SQL Server CE 聯(lián)機(jī)手冊》中的用于 SQL Server CE 的 SQL 參考。
cmd.CommandText = “UPDATE TestTbl SET col2 = 'some new value' WHERE col1 = 0”;cmd.ExecuteNonQuery();讀取 SQL Server CE 表中的數(shù)據(jù)
1.設(shè)置命令對象以使用 SELECT 語句,然后通過執(zhí)行 SqlCeCommand.ExecuteReader 創(chuàng)建數(shù)據(jù)讀取器的實(shí)例。
cmd.CommandText = “SELECT * FROM TestTbl”;
rdr = cmd.ExecuteReader();
while(rdr.Read())
{
MessageBox.Show(“ col1 = ” + rdr.GetInt32(0)+
“ col2 = ” + rdr.GetString(1)+
“ col3 = ” + rdr.GetSqlMoney(2));
}
} 2.使用 SqlCeException 捕獲任何錯(cuò)誤,然后關(guān)閉與數(shù)據(jù)庫的連接。
catch(SqlCeException e){
ShowErrors(e);} finally {
if(conn.State == ConnectionState.Open)
conn.Close();} }
public static void ShowErrors(SqlCeException e)
{
SqlCeErrorCollection errorCollection = e.Errors;
StringBuilder bld = new StringBuilder();
foreach(SqlCeError err in errorCollection)
{
bld.Append(“n Error Code: ” + err.HResult.ToString(“X”));
bld.Append(“n Message
: ” + err.Message);
bld.Append(“n Minor Err.: ” + err.NativeError);
bld.Append(“n Source
: ” + err.Source);
foreach(int numPar in err.NumericErrorParameters)
{
if(0!= numPar)bld.Append(“n Num.Par.: ” + numPar);
}
foreach(string errPar in err.ErrorParameters)
{
if(String.Empty!= errPar)bld.Append(“n Err.Par.: ” + errPar);
}
MessageBox.Show(bld.ToString());
bld.Remove(0, bld.Length);
}
} } 有關(guān) SQL Server CE 中的錯(cuò)誤處理的更多信息,請參見《SQL Server CE 聯(lián)機(jī)手冊》中的錯(cuò)誤處理。
第五篇:zendframework數(shù)據(jù)庫操作總結(jié)
最近在用ZF開發(fā)東西,雖然ZF還不是那么的完美,但是已經(jīng)足夠快的提高開發(fā)效率了,對于ZF運(yùn)行效率不高的問題,等系統(tǒng)運(yùn)行的時(shí)候再說,開發(fā)的時(shí)候還是盡量用JS JQuery Ajax等技術(shù)解決吧。由于也是初級學(xué)習(xí),所以對于一些基本的數(shù)據(jù)庫操作不是很熟練,參考了網(wǎng)上比較全面的數(shù)據(jù)庫操作,在這里總結(jié)一二。
像是如果取得某一行的某個(gè)字段值的過程是這樣的,先用$result=$db->fetchCol(。。)返回一個(gè)數(shù)組,然后取數(shù)組的第一個(gè)值,即$result[0]就是所要取得值了。Zend_Db數(shù)據(jù)庫知識 例子: Model文件:
$this->fetchAll(“is_jian=1″,”id DESC”,0,2)->toArray();//根據(jù)is_jian=1,按id倒序排列取前2條記錄當(dāng)?shù)谝粋€(gè)參數(shù)為null時(shí),則直接按id倒序排列ASC為正序。路由文件:
$video=new Video();//實(shí)例化數(shù)據(jù)庫類
$this->view->get2Video =$video->get2Video();//取到2條首頁推薦的數(shù)據(jù) index.phtml文件:
get2Video as $video): ?> =$video['id'];?> =$video['name'];?> endforeach;?> 添加引號防止數(shù)據(jù)庫攻擊 quote用法
$value = $db->quote(‘St John”s Wort’);// $value 現(xiàn)在變成了 ‘”St John”s Wort”‘(注意兩邊的引號)// 為數(shù)組加引號
$value = $db->quote(array(‘a(chǎn)’, ‘b’, ‘c’));// $value 現(xiàn)在變成了 ‘”a”, “b”, “c”‘(“,”分隔的字符串)quoteInto用法
echo $where = $db->quoteInto(‘id = ?’, 1);// $where 現(xiàn)在為 ‘id = “1″‘(注意兩邊的引號)// 在where語句中為數(shù)組加上引號
$where = $db->quoteInto(‘id IN(?)’, array(1, 2, 3));// $where 現(xiàn)在為 ‘id IN(“1″, “2″, “3″)’(一個(gè)逗號分隔的字符串)(1)數(shù)據(jù)查詢總結(jié)
直接進(jìn)行查詢.(使用完整的sql語句)//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);// 使用PDOStatement對象$result將所有結(jié)果數(shù)據(jù)放到一個(gè)數(shù)組中 $videoArray = $result->fetchAll();
fetchAll用法
fetchAll($where = null, $order = null, $count = null, $offset = null)取回結(jié)果集中所有字段的值,作為連續(xù)數(shù)組返回,如果參數(shù)不設(shè)置就寫成null 可以取回結(jié)果集的指定條數(shù)
$videoArray=$this->fetchAll(“is_jian=1 and is_guo=1″,”id DESC”,0,2)->toArray();fetchAssoc用法
fetchAssoc($sql, $bind = array())取回結(jié)果集中所有字段的值,作為關(guān)聯(lián)數(shù)組返回, 第一個(gè)字段作為碼 $db = $this->getAdapter();$videoArray=$db->fetchAssoc(“
SELECT
*
FROM
m_video
WHERE
`is_jian` = :title”,array(‘title’ => ’1′));fetchCol用法
fetchCol($sql, $bind = array())取回所有結(jié)果行的第一個(gè)字段名 $db = $this->getAdapter();$videoArray=$db->fetchCol(“
SELECT
name
FROM
m_video
WHERE
`is_jian` = :title”,array(‘title’ => ’1′));fetchOne用法
fetchOne($sql, $bind = array())只取回第一個(gè)字段值
$db = $this->getAdapter();echo $videoArray=$db->fetchOne(“SELECT count(*)FROM m_video WHERE `is_jian` = :title”,array(‘title’ => ’1′));fetchPairs用法
fetchPairs($sql, $bind = array())取回一個(gè)相關(guān)數(shù)組,第一個(gè)字段值為碼(id),第二個(gè)字段為值(name)返回:Array([1] => 十二生肖奇緣 [2] => 桃花運(yùn)),1,2:為id字段。$db = $this->getAdapter();$videoArray=$db->fetchPairs(“SELECT id, name FROM m_video WHERE is_jian = :title”,array(‘title’ => ’1′));fetchRow用法
fetchRow($where = null, $order = null)只取回結(jié)果集的第一行
$videoArray=$this->fetchRow(“is_jian=1 and is_guo=1″, ‘id DESC’)->toArray();query用法
//function 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(‘十二生肖奇緣’, ’1′));//$result->setFetchMode(Zend_Db::FETCH_OBJ);//FETCH_OBJ為默認(rèn) 值,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);//得到結(jié)果集的第一個(gè)字段,比如0為id號,用于只取一個(gè)字段的情況 print_r($rows);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’)// 按什么排序列,參加為數(shù)組(多個(gè)字段)或字符串(一個(gè)字段)->group()//分組
->having()//分組查詢數(shù)據(jù)的條件
->distinct()// 無參數(shù),去掉重復(fù)的值。有時(shí)候與groupby返回的結(jié)果一樣->limit(10);// 讀取結(jié)果使用綁定的參數(shù)
$params = array(‘is_guo’ => ’1′,’name’=>’十二生肖奇緣’);//$sql = $select->__toString();//得到查詢語句,可供調(diào)試 $result = $db->fetchAll($select,$params);執(zhí)行select的查詢
$stmt = $db->query($select);$result = $stmt->fetchAll();或用
$stmt = $select->query();$result = $stmt->fetchAll();如果直接用
$db->fetchAll($select)結(jié)果一樣 多表聯(lián)合查詢用法
$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’);//多表聯(lián)合查詢
$videoArray = $db->fetchAll($select,$params);find()方法,可以使用主鍵值在表中檢索數(shù)據(jù).// 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)數(shù)據(jù)刪除總結(jié)
第一種方法:可以刪任意表
//quoteInto($text, $value, $type = null, $count = null)$table = ‘m_video’;// 設(shè)定需要?jiǎng)h除數(shù)據(jù)的表 $db = $this->getAdapter();$where = $db->quoteInto(‘name = ?’, ‘ccc’);// 刪除數(shù)據(jù)的where條件語句 echo $rows_affected = $db->delete($table, $where);// 刪除數(shù)據(jù)并得到影響的行數(shù) 第二種方法:只能刪除本表中的 //delete用法
// delete($where)$where = “name = ‘bbb’”;echo $this->delete($where);// 刪除數(shù)據(jù)并得到影響的行數(shù)(3)數(shù)據(jù)更新總結(jié)
第一種方法:可以更新任意表
// 以”列名”=>”數(shù)據(jù)”的格式構(gòu)造更新數(shù)組,更新數(shù)據(jù)行 $table = ‘m_video’;// 更新的數(shù)據(jù)表 $db = $this->getAdapter();$set = array(‘name’ => ‘蝶影重重’, ‘clicks’ => ’888′,);$where = $db->quoteInto(‘id = ?’, ’10′);// where語句 // 更新表數(shù)據(jù),返回更新的行數(shù)
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);// 更新表數(shù)據(jù),返回更新的行數(shù)(4)數(shù)據(jù)插入總結(jié)
第一種方法:可以在任意表中插入數(shù)據(jù)
$table = ‘m_gao’;// 插入數(shù)據(jù)的數(shù)據(jù)表 $db = $this->getAdapter();// 以”列名”=>”數(shù)據(jù)”的格式格式構(gòu)造插入數(shù)組,插入數(shù)據(jù)行 $row = array(‘title’ => ‘大家好。111′, ‘content’ => ‘影視網(wǎng)要改成用zend framework開發(fā)啊’, ‘time’ => ’2009-05-04 17:23:36′,);// 插入數(shù)據(jù)行并返回插入的行數(shù)
$rows_affected = $db->insert($table, $row);// 最后插入的數(shù)據(jù)id echo $last_insert_id = $db->lastInsertId();$row=array(‘name’=>’curdate()’, ‘a(chǎn)ddress’ => new Zend_Db_Expr(‘curdate()’))這樣子字段name會插入一個(gè)curdate()的字符串,而address插入一個(gè)時(shí)間值(curdate()的結(jié)果2009-05-09)第二種方法:只能適合本表中的還沒有總結(jié)出來
(5)事務(wù)處理
$table = ‘m_gao’;// 插入數(shù)據(jù)的數(shù)據(jù)表 $db = $this->getAdapter();$db->beginTransaction();//Zend_Db_Adapter會回到自動(dòng)commit模式下,直到你再次調(diào)用 beginTransaction()方法
// 以”列名”=>”數(shù)據(jù)”的格式格式構(gòu)造插入數(shù)組,插入數(shù)據(jù)行 $row = array(‘id’=>null, ‘title’ => ‘大家好。111′, ‘content’ => ‘影視網(wǎng)要改成用zend framework開發(fā)啊’, ‘time’ => ’2009-05-04 17:23:36′,);try { // 插入數(shù)據(jù)行并返回插入的行數(shù)
$rows_affected = $db->insert($table, $row);// 最后插入的數(shù)據(jù)id $last_insert_id = $db->lastInsertId();$db->commit();// 事務(wù)提交 }catch(Exception $e){ $db->rollBack();echo ‘捕獲異常:’.$e->getMessage();//打出異常信息 } echo $last_insert_id;(5)其他
$db = $this->getAdapter();$tables = $db->listTables();//列出當(dāng)前數(shù)據(jù)庫中的所有表
$fields = $db->describeTable(‘m_video’);//列出一個(gè)表的字段情況 ======
使用Zend_Db_Select方法是一種不受數(shù)據(jù)庫約束構(gòu)建select的sql語句的工具(ares注:用戶可以使用該方法生成查詢的sql語句,而不需要考慮各種數(shù)據(jù) 庫sql語句的差別)。雖然該方法明顯還不完善,但是的確為我們提供一種方 法,幫助我們在不同的后臺數(shù)據(jù)庫進(jìn)行相同的查詢工作。除此之外,它還可 以避免sql語句攻擊。這種方法可以去相關(guān)頁面查閱。