第一篇:數據庫操作命令總結
大二學期總結
--【1】 查詢PXSCJ數據庫的XSB表中各個同學的姓名、專業和總學分。--select XM ,ZY ,ZXF--from XSB;--【2】查詢XSB表中網絡工程專業同學的學號、姓名和總學分。--select XH,XM,ZXF--from XSB--where ZY='網絡工程';--【3】查詢XSB表中網絡工程系同學的XH、XM和ZXF,--結果中各列的標題分別指定為學號、姓名和總學分--select XH 學號,XM 姓名,ZXF 總學分--from XSB;--【4】查詢網絡工程專業學生的學號,姓名和年齡,按年齡降序輸出。--select xh,xm,year(cssj)--from xsb--order by year(cssj);--【5】求選修101課程的學生的平均成績,最高分,最低分。--select AVG(CJ),MAX(CJ),MIN(CJ)--from CJB--where KCH='101';--【7】分組統計各專業男生,女生的人數。--select ZY 專業,count(zy)男--from xsb--where xb='true'--group by zy;--select ZY 專業,count(zy)女--from xsb--where xb ='false'--group by zy;--【8】查詢XSB表中姓“王”且單名的學生情況。--select *--from XSB--where XM like '王_'--【9】查找選修了課程號為206的課程的學生情況。--select *--from kcb,xsb,cjb--where cjb.xh=xsb.xh and kcb.kch='206';
--【10】查找網絡工程專業每個學生的學號、姓名、課程名及成績。--select XSB.XH ,XM,KCH,CJ--from xsb,cjb--where xsb.xh=cjb.xh and zy='網絡工程';--【11】查找選修了“計算機基礎”課程且成績在80分以上的學生學號、姓名、課程名及成績。--select XSB.XH,XSB.XM,KCB.KCM,CJ--from CJB, XSB ,KCB--where XSB.XH=CJB.XH and KCB.KCM = '計算機基礎'and--CJ>80;--【12】 求被選修的各門課程的平均成績和選修該課程的人數。--select KCB.XS 學生人數,AVG(CJ)平均成績--from KCB,CJB--group by xs;--【13】
查找平均成績在85分以上的學生的學號和平均成績。--select XSB.XH,AVG(CJ)平均成績--from CJB,XSB--where CJB.XH=XSB.Xh--group by XSB.xh--HAVING AVG(CJ)>85;--【14】查找未選修離散數學的學生情況。--select *--from XSB,KCB,CJB--where XSB.XH=CJb.XH and cjb.kch=kcb.kch and KCM!='離散數學';--【15】查找比所有網絡工程系的學生年齡都大的學生。--select *--from XSB--where cssj<(--select MIN(cssj)--from xsb--where ZY = '網絡工程');--【16】創建網絡工程專業學生的平均成績視圖V_CS_CJ_AVG,--包括學號(在視圖中列名為num)和平均成績(在視圖中列名為score_avg)。--create VIEW V_CS_CJ_AVG(num,score_avg)
--AS--select XSB.XH num ,AVG(CJ)score_avg--from CJB,XSB--where CJB.XH=XSB.XH and ZY= '網絡工程'--group by xsb.xh;--【17】
一次向XSB表中插入兩行數據:
--('091101', '王海', 1, '1991-05-10', '軟件工程', 50, NULL)--和('091102', '李娜', 0, '1991-04-12', '軟件工程', 52, NULL)--INSERT--INTO XSB(xh,xm,xb,cssj,zy,zxf,bz)--values('091102', '李娜', '0', '1991-04-12', '軟件工程', '52', 'NULL'),--('091101', '王海', '1', '1991-05-10', '軟件工程', '50', 'NULL');--【18】
將XSB表(數據以附錄A中XSB表的樣本數據為準)中所有學生的總學分都增加10。
--將姓名為“羅ice”的同學的專業改為“網絡工程”,備注改為“提前修完學分”,學號改為081261。--update XSB--set ZY='網絡工程', BZ='提前修完學分'--where XM='羅ice';--【19】查詢XSB表中不在1989年出生的學生情況。--select *--from XSB--where cssj<>1989;
第二篇:數據庫操作文檔實踐總結
Oracle導入操作
1、點擊服務器開始菜單選擇運行,輸入CMD后回車打開命令輸入框
2、輸入命令imp
3、根據提示輸入要導入的oracle用戶和口令(用戶名:rmp_jms 口令:1)
4、根據提示輸入要導入數據文件如)rmpjms2012908.dmp
5、根據提示輸入緩存大小 回車
6、提示只列出導入文件內容 no 回車
7、忽略創建錯誤 yes 回車
8、導入權限 no 回車
9、導入數據 yes 回車
10、導入整個文件 yes 回車
Oracle導出命令
1、運行cmd進入dos窗口
2、輸入命令exp
3、根據提示輸入要導入的oracle用戶和口令(用戶:rmp_jms 口令:1)
4、根據提示輸入緩沖大小 回車
f:...(例
5、根據提示輸入要導出數據存放位置文件名(例如)f:...rmpjms20120908.dmp
6、根據提示選擇1.完整的數據庫2.用戶(U)3.表(T)用戶(U)
回車
7、是否導出權限 no 回車
8、導出表數據 yes 回車
9、壓縮區 yes 回車
10、要導出的用戶:rmp_jms 回車
11、要導出的用戶: 直接回車
第三篇:SQLCE數據庫操作總結
創建新的數據庫
SQL Server CE 中的數據庫是存儲結構化數據的表集合。在可以存儲數據庫之前,必須創建數據庫。在創建數據庫之后,可以創建保存數據的表。
在本節中,您將創建一個新的數據庫,然后創建一個表,最后將數據添加到該表中。若要執行這些步驟,請使用 SQL Server CE(System.Data.SqlServerCe).NET Framework 精簡版數據提供程序的 SqlCeConnection、SqlCeEngine 和 SqlCeCommand 類。
注意 不能在此任務中運行僅用于特定步驟的代碼。有關完整代碼列表,請參見代碼列表:使用 SQL Server CE 數據庫。
創建新的 SQL Server CE 數據庫
1.啟動 Visual Studio.NET,然后打開一個新項目。
2.創建對使用的命名空間的引用。
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.創建 WalkThrough 類。
public class WalkThrough {
static void Main()
{
SqlCeConnection conn = null;
try
{ 4.驗證具有您打算使用的名稱的數據庫是否已存在。
if(File.Exists(“Test.sdf”))
File.Delete(“Test.sdf”);5.使用 System.Data.SqlCeEngine 對象創建名為 Test.sdf 的空數據庫。
注意 SQL Server CE 中,數據庫名稱的文件擴展名為.sdf。
SqlCeEngine engine = new SqlCeEngine(“Data Source = Test.sdf”);
engine.CreateDatabase();6.連接到這個新數據庫。
conn = new SqlCeConnection(“Data Source = Test.sdf”);conn.Open();創建新表
1.使用 System.Data.SqlCeCommand 創建命令類的實例。
SqlCeCommand cmd = conn.CreateCommand();2.運行命令 cmd 創建表。用于創建表的指令必須在 cmd.CommandText 所包含的 SQL 代碼中。
若要使用 SQL Server CE 的 SQL 編程語言創建表,請使用 CREATE TABLE 語法。有關更多信息,請參見《SQL Server CE 聯機手冊》中的用于 SQL Server CE 的 SQL 參考。
cmd.CommandText = “CREATE TABLE TestTbl(col1 int PRIMARY KEY, col2 ntext, col3 money)”;cmd.ExecuteNonQuery();將數據添加到新表中
1.運行命令以添加數據行。與創建表相同,用于添加行的指令也必須在 cmd.CommandText
所包含的 SQL 代碼中。若要使用 SQL Server CE 的 SQL 編程語言將行添加到表中,請使用 INSERT 語法。有關更多信息,請參見《SQL Server CE 聯機手冊》中的用于 SQL Server CE 的 SQL 參考。
cmd.CommandText = “INSERT INTO TestTbl(col1, col2, col3)VALUES(0, 'abc', 15.66)”;cmd.ExecuteNonQuery();2.創建命令,使用參數將數據多次插入表中。
參數可以更高效地查詢數據庫,因為可以使用一組包含參數的 SQL 語句插入多個值。有關更多信息,請參見《SQL Server CE 聯機手冊》的在查詢中使用參數。
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.執行參數化命令,將數據插入表中。
cmd.Parameters[“p1”].Value = 1;cmd.Parameters[“p2”].Value = “abc”;cmd.Parameters[“p3”].Value = 15.66;cmd.ExecuteNonQuery();4.清除參數,并檢查已插入表中的數據。
若要使用 SQL Server CE 的 SQL 編程語言讀取現有數據,請使用 SELECT 語法。有關更多信息,請參見《SQL Server CE 聯機手冊》中的用于 SQL Server CE 的 SQL 參考。
cmd.Parameters.Clear();//Set the command text to a SELECT query.// cmd.CommandText = “SELECT * FROM TestTbl”;讀取 SQL Server CE 數據庫數據
讀取數據庫數據是一種常見的任務,通常涉及對表行信息的訪問。為使用
System.Data.SqlServerCe 執行此任務,您需要 SqlCeDataReader 和 SqlCeCommand 對象。注意 有關完整代碼列表,請參見代碼列表:使用 SQL Server CE 數據庫。
1.調用 SqlCeCommand 對象的 ExecuteReader 方法以創建 SqlCeDataReader 的實例。
SqlCeDataReader rdr = cmd.ExecuteReader();2.指示數據讀取器 rdr 在行存在時在每行的列中顯示數據。
while(rdr.Read()){MessageBox.Show(“col1 = ” + rdr.GetInt32(0)+
“col2 = ” + rdr.GetString(1)+
“col3 = ” + rdr.GetSqlMoney(2));} 更改 SQL Server CE 數據庫中的數據
在創建表后,可以以多種方式修改表中的數據:更改特定數據的屬性,添加和刪除數據行,甚至還可以通過修改表中的列來更改存儲數據的方式。
在本節中,您將更改表項的值,查找更改的表的數據并處理所有錯誤。為執行這些步驟,您將使用在前面的任務中使用的類:SqlCeCommand 和 SqlCeDataReader。另外,您將使用 SqlCeException 進行錯誤處理。
注意 不能在此任務中運行僅用于特定步驟的代碼。有關完整代碼列表,請參見代碼列表:使用 SQL Server CE 數據庫。
更新 SQL Server CE 表中的數據
? 設置命令對象以使用 UPDATE 語句。
若要使用 SQL Server CE 的 SQL 編程語言更改行列的值,請使用 UPDATE 語法。有關更多信息,請參見《SQL Server CE 聯機手冊》中的用于 SQL Server CE 的 SQL 參考。
cmd.CommandText = “UPDATE TestTbl SET col2 = 'some new value' WHERE col1 = 0”;cmd.ExecuteNonQuery();讀取 SQL Server CE 表中的數據
1.設置命令對象以使用 SELECT 語句,然后通過執行 SqlCeCommand.ExecuteReader 創建數據讀取器的實例。
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 捕獲任何錯誤,然后關閉與數據庫的連接。
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);
}
} } 有關 SQL Server CE 中的錯誤處理的更多信息,請參見《SQL Server CE 聯機手冊》中的錯誤處理。
第四篇:zendframework數據庫操作總結
最近在用ZF開發東西,雖然ZF還不是那么的完美,但是已經足夠快的提高開發效率了,對于ZF運行效率不高的問題,等系統運行的時候再說,開發的時候還是盡量用JS JQuery Ajax等技術解決吧。由于也是初級學習,所以對于一些基本的數據庫操作不是很熟練,參考了網上比較全面的數據庫操作,在這里總結一二。
像是如果取得某一行的某個字段值的過程是這樣的,先用$result=$db->fetchCol(。。)返回一個數組,然后取數組的第一個值,即$result[0]就是所要取得值了。Zend_Db數據庫知識 例子: Model文件:
$this->fetchAll(“is_jian=1″,”id DESC”,0,2)->toArray();//根據is_jian=1,按id倒序排列取前2條記錄當第一個參數為null時,則直接按id倒序排列ASC為正序。路由文件:
$video=new Video();//實例化數據庫類
$this->view->get2Video =$video->get2Video();//取到2條首頁推薦的數據 index.phtml文件:
get2Video as $video): ?> =$video['id'];?> =$video['name'];?> endforeach;?> 添加引號防止數據庫攻擊 quote用法
$value = $db->quote(‘St John”s Wort’);// $value 現在變成了 ‘”St John”s Wort”‘(注意兩邊的引號)// 為數組加引號
$value = $db->quote(array(‘a’, ‘b’, ‘c’));// $value 現在變成了 ‘”a”, “b”, “c”‘(“,”分隔的字符串)quoteInto用法
echo $where = $db->quoteInto(‘id = ?’, 1);// $where 現在為 ‘id = “1″‘(注意兩邊的引號)// 在where語句中為數組加上引號
$where = $db->quoteInto(‘id IN(?)’, array(1, 2, 3));// $where 現在為 ‘id IN(“1″, “2″, “3″)’(一個逗號分隔的字符串)(1)數據查詢總結
直接進行查詢.(使用完整的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將所有結果數據放到一個數組中 $videoArray = $result->fetchAll();
fetchAll用法
fetchAll($where = null, $order = null, $count = null, $offset = null)取回結果集中所有字段的值,作為連續數組返回,如果參數不設置就寫成null 可以取回結果集的指定條數
$videoArray=$this->fetchAll(“is_jian=1 and is_guo=1″,”id DESC”,0,2)->toArray();fetchAssoc用法
fetchAssoc($sql, $bind = array())取回結果集中所有字段的值,作為關聯數組返回, 第一個字段作為碼 $db = $this->getAdapter();$videoArray=$db->fetchAssoc(“
SELECT
*
FROM
m_video
WHERE
`is_jian` = :title”,array(‘title’ => ’1′));fetchCol用法
fetchCol($sql, $bind = array())取回所有結果行的第一個字段名 $db = $this->getAdapter();$videoArray=$db->fetchCol(“
SELECT
name
FROM
m_video
WHERE
`is_jian` = :title”,array(‘title’ => ’1′));fetchOne用法
fetchOne($sql, $bind = array())只取回第一個字段值
$db = $this->getAdapter();echo $videoArray=$db->fetchOne(“SELECT count(*)FROM m_video WHERE `is_jian` = :title”,array(‘title’ => ’1′));fetchPairs用法
fetchPairs($sql, $bind = array())取回一個相關數組,第一個字段值為碼(id),第二個字段為值(name)返回:Array([1] => 十二生肖奇緣 [2] => 桃花運),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)只取回結果集的第一行
$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為默認 值,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);//得到結果集的第一個字段,比如0為id號,用于只取一個字段的情況 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’)// 按什么排序列,參加為數組(多個字段)或字符串(一個字段)->group()//分組
->having()//分組查詢數據的條件
->distinct()// 無參數,去掉重復的值。有時候與groupby返回的結果一樣->limit(10);// 讀取結果使用綁定的參數
$params = array(‘is_guo’ => ’1′,’name’=>’十二生肖奇緣’);//$sql = $select->__toString();//得到查詢語句,可供調試 $result = $db->fetchAll($select,$params);執行select的查詢
$stmt = $db->query($select);$result = $stmt->fetchAll();或用
$stmt = $select->query();$result = $stmt->fetchAll();如果直接用
$db->fetchAll($select)結果一樣 多表聯合查詢用法
$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’);//多表聯合查詢
$videoArray = $db->fetchAll($select,$params);find()方法,可以使用主鍵值在表中檢索數據.// 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)數據刪除總結
第一種方法:可以刪任意表
//quoteInto($text, $value, $type = null, $count = null)$table = ‘m_video’;// 設定需要刪除數據的表 $db = $this->getAdapter();$where = $db->quoteInto(‘name = ?’, ‘ccc’);// 刪除數據的where條件語句 echo $rows_affected = $db->delete($table, $where);// 刪除數據并得到影響的行數 第二種方法:只能刪除本表中的 //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;(5)其他
$db = $this->getAdapter();$tables = $db->listTables();//列出當前數據庫中的所有表
$fields = $db->describeTable(‘m_video’);//列出一個表的字段情況 ======
使用Zend_Db_Select方法是一種不受數據庫約束構建select的sql語句的工具(ares注:用戶可以使用該方法生成查詢的sql語句,而不需要考慮各種數據 庫sql語句的差別)。雖然該方法明顯還不完善,但是的確為我們提供一種方 法,幫助我們在不同的后臺數據庫進行相同的查詢工作。除此之外,它還可 以避免sql語句攻擊。這種方法可以去相關頁面查閱。
第五篇:數據庫操作
Excel技巧:Excel如何快速統計各銷售人員的銷售總金額?
繼續解決Q群小伙伴提出的問題,Excel如何快速統計各銷售人員的銷售總金額?題目問得好像是個銷售問題,其實針對各種分類匯總的數據統計。這次用透視表的方法給大家分享一下快速統計的方法。
場景:適合財務、銷售、HR等數據統計的辦公人士。問題:Excel如何快速統計各銷售人員的銷售總金額? 解答:利用Excel的數據透視表搞定!
具體操作如下:將光標放置于銷售人員銷售表格區域中任意單元格,然后再插入選項卡中點擊“數據透視表”功能。