第一篇:黑馬程序員C語言教程: CC++培訓(xùn)專家:漫談軟件編碼風(fēng)格
傳智播客C/C++培訓(xùn)專家:漫談軟件編碼風(fēng)格
通過建立代碼編寫規(guī)范,形成開發(fā)小組編碼約定,提高程序的可靠性、可讀性、可修改性、可維護性、一致性,保證程序代碼的質(zhì)量,繼承軟件開發(fā)成果,充分利用資源。提高程序的可繼承性,使開發(fā)人員之間的工作成果可以共享。代碼的風(fēng)格主要有以下幾點:
1、縮進
縮進以4個空格為單位。預(yù)處理語句、全局數(shù)據(jù)、函數(shù)原型、標題、附加說明、函數(shù)說明、標號等均頂格書寫。語句塊的“{”“}”配對對齊,并與其前一行對齊,語句塊類的語句縮進建議每個“{”“}”單獨占一行。
2、空格
變量、類、常量數(shù)據(jù)和函數(shù)在其類型,修飾(如 __fastcall 等)名稱之間適當空格并據(jù)情況對齊。關(guān)鍵字原則上空一格,如: if(...)等,運算符的空格規(guī)定如下:“::”、“->”、“[”、“]”、“++”、“--”、“~”、“!”、“+”、“-”(指正負號),“&”(取址或引用)、“*”(指使用指針時)等幾個運算符兩邊不加空格(其中單目運算符系指與操作數(shù)相連的一邊),其它運算符(包括大多數(shù)二目運算符和三目運算符“?:”兩邊均加一空格,“(”、“)”運算符在其內(nèi)側(cè)空一格,在作函
數(shù)定義時還可據(jù)情況多空或不空格來對齊,但在函數(shù)實現(xiàn)時可以不用?!?”運算符只在其后空一格,需對齊時也可不空或多空格,“sizeof”運算符建議也在其后空一格,不論是否有括號,對語句行后加的注釋應(yīng)用適當空格與語句隔開并盡可能對齊。
3、對齊
原則上關(guān)系密切的行應(yīng)對齊,對齊包括類型、修飾、名稱、參數(shù)等各部分對齊。另每一行的長度不應(yīng)超過屏幕太多,必要時適當換行,換行時盡可能在“,”處或運算符處,換行后最好以運算符打頭,并且以下各行均以該語句首行縮進,但該語句仍以首行的縮進為準,即如其下一行為“{”應(yīng)與首行對齊。
變量定義最好通過添加空格形成對齊,同一類型的變量最好放在一起。
4、空行
程序文件結(jié)構(gòu)各部分之間空兩行,若不必要也可只空一行,各函數(shù)實現(xiàn)之間一般空兩行,由于BCB會自動產(chǎn)生一行“//------”做分隔,另因每個函數(shù)還要有函數(shù)說明注釋,故通常只需空一行或不空,但對于沒有函數(shù)說明的情況至少應(yīng)再空一行。對自己寫的函數(shù),建議也加上“//------”做分隔。函數(shù)內(nèi)部數(shù)據(jù)與代碼之間應(yīng)空至少一行,代碼中適當處應(yīng)以空行空開,建議在代碼中出現(xiàn)變量聲明時,在其前空一行。類中四個“p”之間至少空一行,在其中的數(shù)據(jù)與函數(shù)之間也應(yīng)空行。
5、注釋
對注釋有以下三點要求: A.必須是有意義。B.必須正確的描述了程序。C.必須是最新的。
注釋必不可少,但也不應(yīng)過多,以下是四種必要的注釋: A.標題、附加說明。
B.函數(shù)說明。對幾乎每個函數(shù)都應(yīng)有適當?shù)恼f明,通常加在函數(shù)實現(xiàn)之前,在沒有函數(shù)實現(xiàn)部分的情況下則加在函數(shù)原型前,其內(nèi)容主要是函數(shù)的功能、目的、算法等說明,參數(shù)說明、返回值說明等,必要時還要有一些如特別的軟硬件要求等說明。C.在代碼不明晰或不可移植處必須有一定的說明。D.及少量的其它注釋。
注釋有塊注釋和行注釋兩種,分別是指:“/**/”和“//”建議對A用塊注釋,D用行注釋,B、C則視情況而定,但應(yīng)統(tǒng)一,至少在一個單元中B類注釋形式應(yīng)統(tǒng)一。
6、代碼長度:
對于每一個函數(shù)建議盡可能控制其代碼長度為53行左右,超過53行的代碼要重新考慮將其拆分為兩個或兩個以上的函數(shù)。函數(shù)拆分規(guī)則應(yīng)該一不破壞原有算法為基礎(chǔ),同時拆分出來的部分應(yīng)該是可以重復(fù)利用的。對于在多個模塊或者窗體中都要用到的重復(fù)性代碼,完全可以將起獨立成為一個具備公用性質(zhì)的函數(shù),放置于一個公用模塊中(Common.cpp/Common.h)。
第二篇:黑馬程序員C語言教程: CC++培訓(xùn)專家-預(yù)處理命令使用詳解
傳智播客C/C++培訓(xùn)專家:預(yù)處
理命令詳解
作為一枚C/C++程序猿,在我們編寫和查看C/C++源代碼的過程中會遇到各種編譯指令,這些指令稱為預(yù)處理命令。預(yù)處理命令雖然不是C/C+的一部分,但卻擴展了C程序的設(shè)計環(huán)境,下面?zhèn)髦遣タ虲/C+培訓(xùn)專家將向大家介紹如何應(yīng)用預(yù)處理程序和注釋簡化程序開發(fā)過程,并提高程序的可讀性。
ANSI標準定義的C語言所有預(yù)處理命令均以符號#開頭,比如我寫程序時常用的:
#define,#undef,#include,#if,#else,#elif,#endif,#ifdef,#ifndef, #error 1.#define和 #undef 宏定義命令的一般形式為:
#define[MacroName][MacroValue],示例如下: #defineITHEIMA 傳智播客黑馬程序員
在源程序中每次遇到ITHEIMA時,均以定義的值傳智播客黑馬程序員代換它。
? 在使用該宏時,有以下幾點注意事項:
? 該語句沒有分號。在標識符和串之間可以有任意個空格。? 定義宏的時候,可以使用之前已經(jīng)定義好的宏。
? 如果串長于一行,可以在該行末尾用一反斜杠' '續(xù)行。
#defineLONG_STRING“good good study,day day up!” ? 在定義宏標識符時,字母一般需要大寫。? 預(yù)處理運算符的使用:
? #--該符號是“字符串化”的意思,出現(xiàn)在宏定義中的#是把跟在后面的參數(shù)轉(zhuǎn)換成一個字符串
#define ERROR_LOG(module)
fprintf(stderr, “error: ”#module“n”)ERROR_LOG(“add”);轉(zhuǎn)換為 fprintf(stderr,“error: ”add“n”);ERROR_LOG(devied =0);轉(zhuǎn)換為 fprintf(stderr,“error: devied=0n”);? ##--是連接符號,將多個串連接到一起。char *szStr = “傳播播客_黑馬程序員”;#define ITCAST(exp)cout < 2.#include 命令#i nclude使編譯程序?qū)⒘硪辉次募度霂в校nclude的源文件,被讀入的源文件必須用雙引號或尖括號括起來。例如: #include“stdio.h”或者#include 這兩行代碼均使用C編譯程序讀入并編譯用于處理磁盤文件庫的子程序。將文件嵌入#i nclude命令中的文件內(nèi)是可行的,這種方 式稱為嵌套的嵌入文件,嵌套層次依賴于具體實現(xiàn)。 ? 如果顯式路徑名為文件標識符的一部分,則僅在那些子目錄中搜索被嵌入文件。 例如: #include “../include/head.h” ? 如果文件名用雙引號括起來,則首先檢索當前工作目錄。如果未發(fā)現(xiàn)文件,則在命令行中說明的所有目錄中搜索。如果仍未發(fā)現(xiàn)文件,則搜索實現(xiàn)時定義的標準目錄。例如: include “head.h” ? 如果文件名被尖括號括起來,則首先在編譯命令行中的目錄內(nèi)檢索。如果文件沒找到,則檢索標準目錄,不檢索當前工作目錄。 例如: include
它與#endif之間的代碼,否則跳過這些代碼。命令#endif標識一個#if塊的結(jié)束。
跟在#if后面的表達式在編譯時求值,因此它必須僅含常量及已定義過的標識符,不可使用變量。表達式不許含有操作符sizeof(sizeof也是編譯時求值)。
? #else命令的功能有點象C語言中的else;#else建立另一選擇(在#if失敗的情況下)。注意,#else屬于#if塊。
? #elif命令意義與ELSE IF 相同,它形成一個if else-if階梯狀語句,可進行多種編譯選擇。#elif 后跟一個常量表達式。如果表達式為true,則編譯其后的代碼塊,不對其它#elif表達式進行測試。否則,順序測試下一塊。?
4.#error 命令#error強迫編譯程序停止編譯,主要用于程序調(diào)試。該指令使預(yù)處理器發(fā)出一條錯誤消息,該消息包含指令中的文本.這條指令的目的就是在程序崩潰之前能夠給出一定的信息。
5.#ifdef 和 #ifndef 條件編譯的另一種方法是用#ifdef與#ifndef命令,它們分別表示“如果有定義”及“如果無定義”。# ifdef的一般形式是:
# ifdef macroname statement sequence
#endif #ifdef與#ifndef可以用于#if、#else,#elif語句中,但必須與一個#endif。
define MAX 91 #include
int main(){ #ifdef MAX cout<<“hello,MAX!”< #else cout<<“where is MAX?”< #endif #ifndef LEO cout<<“LEO is not defined”< #endif return 0;} 今天關(guān)于預(yù)處理命令的知識點傳智播客C/C+培訓(xùn)專家就為大家接受到這里, 歡迎大家留言交流.
第三篇:黑馬程序員C語言教程: CC++培訓(xùn)專家-編寫高效C語言的四大絕招
傳智播客C/C++培訓(xùn)專家:編寫高效C語言的四大絕招
C語言是很多程序猿的入門語言,而且C語言也是一門用不過時的語言。編寫高效簡潔的C語言代碼,是許多軟件工程師追求的目標。今天傳智播客C/C++培訓(xùn)專家針對編程工作中的一些體會和經(jīng)驗給大家做相關(guān)的闡述。
第一招:以空間換時間
計算機程序中最大的矛盾是空間和時間的矛盾,那么,從這個角度出發(fā)逆向思維來考慮程序的效率問題,我們就有了解決問題的第1招--以空間換時間。比如說字符串的賦值: 方法A:通常的辦法 #define LEN 32 char string1 [LEN];memset(string1, 0, LEN);strcpy(string1, “This is a example!”);方法B:
const char string2[LEN] =“This is a example!”;char * cp;cp = string2;
從上面的例子可以看出,A和B的效率是不能比的。在同樣的存儲空間下,B直接使用指針就可以操作了,而A需要調(diào)用兩個字符函數(shù)才能完成。B的缺點在于靈活性沒有A好。在需要頻繁更改一個字符串內(nèi)容的時候,A具有更好的靈活性;如果采用方法B,則需要預(yù)存許多字符串,雖然占用了大量的內(nèi)存,但是獲得了程序執(zhí)行的高效率。
第二招:數(shù)學(xué)方法解決問題
現(xiàn)在我們演繹高效C語言編寫的第二招--采用數(shù)學(xué)方法來解決問題。數(shù)學(xué)是計算機之母,沒有數(shù)學(xué)的依據(jù)和基礎(chǔ),就沒有計算機的發(fā)展,所以在編寫程序的時候,采用一些數(shù)學(xué)方法會對程序的執(zhí)行效率有數(shù)量級的提高。舉例如下,求 1~100的和。方法C: int I , j;for(I = 1;I<=100;I ++){ j += I;} 方法D int I;I =(100 *(1+100))/ 2;
這個例子是我印象最深的一個數(shù)學(xué)用例,是我的計算機啟蒙老師考我的。當時我只有小學(xué)三年級,可惜我當時不知道用公式 N×(N+1)
/ 2 來解決這個問題。方法E循環(huán)了100次才解決問題,也就是說最少用了100個賦值,100個判斷,200個加法(I和j);而方法F僅僅用了1個加法,1 次乘法,1次除法。效果自然不言而喻。所以,現(xiàn)在我在編程序的時候,更多的是動腦筋找規(guī)律,最大限度地發(fā)揮數(shù)學(xué)的威力來提高程序運行的效率。
第三招:使用位操作
實現(xiàn)高效的C語言編寫的第三招——使用位操作。減少除法和取模的運算。在計算機程序中數(shù)據(jù)的位是可以操作的最小數(shù)據(jù)單位,理論上可以用“位運算”來完成所有的運算和操作。一般的位操作是用來控制硬件的,或者做數(shù)據(jù)變換使用,但是,靈活的位操作可以有效地提高程序運行的效率。舉例如下: 方法E int I,J;I = 257 /8;J = 456 % 32;方法F int I,J;I = 257 >>3;J = 456-(456 >> 4 << 4);在字面上好像F比E麻煩了好多,但是,仔細查看產(chǎn)生的匯編代碼就會明白,方法E調(diào)用了基本的取模函數(shù)和除法函數(shù),既有函數(shù)調(diào)用,還有很多匯編代碼和寄存器參與運算;而方法F則僅僅是幾句相關(guān)的匯編,代碼更簡潔,效率更高。當然,由于編譯器的不同,可能效率的差距不大,但是,以我目前遇到的MS C ,ARM C 來看,效率的差距還是不小。相關(guān)匯編代碼就不在這里列舉了。
運用這招需要注意的是,因為CPU的不同而產(chǎn)生的問題。比如說,在PC上用這招編寫的程序,并在PC上調(diào)試通過,在移植到一個16位機平臺上的時候,可能會產(chǎn)生代碼隱患。所以只有在一定技術(shù)進階的基礎(chǔ)下才可以使用這招。用移位實現(xiàn)乘除法運算
a=a*4;
b=b/4;
可以改為:
a=a<<2;
b=b>>2;
說明:
除2 = 右移1位 乘2 = 左移1位
除4 = 右移2位 乘4 = 左移2位
除8 = 右移3位 乘8 = 左移3位
......通常如果需要乘以或除以2的n次方,都可以用移位的方法代替。大部分的C編譯器,用移位的方法得到代碼比調(diào)用乘除法子程序生成的代碼效率高。
第四招:匯編嵌入
高效C語言編程的必殺技,第四招——嵌入?yún)R編?!霸谑煜R編語言的人眼里,C語言編寫的程序都是垃圾”。這種說法雖然偏激了一些,但是卻有它的道理。匯編語言是效率最高的計算機語言,但是,不可能靠著它來寫一個操作系統(tǒng)吧?所以,為了獲得程序的高效率,我們只好采用變通的方法--嵌入?yún)R編,混合編程。舉例如下,將數(shù)組一賦值給數(shù)組二,要求每一字節(jié)都相符。char string1[1024],string2[1024];方法G int i;for(i =0;i<1024;i++)*(string2 + i)= *(string1 + i)方法H #ifdef _PC_ int I;for(I =0;I<1024;I++)*(string2 + I)= *(string1 + I);#else #ifdef _ARM_ __asm
{ MOV R0,string1 MOV R1,string2 MOV R2,#0 loop: LDMIA R0!, [R3-R11] STMIA R1!, [R3-R11] ADD R2,R2,#8 CMP R2, #400 BNE loop } #endif 方法G是最常見的方法,使用了1024次循環(huán);方法H則根據(jù)平臺不同做了區(qū)分,在ARM平臺下,用嵌入?yún)R編僅用128次循環(huán)就完成了同樣的操作。這里有朋友會說,為什么不用標準的內(nèi)存拷貝函數(shù)呢?這是因為在源數(shù)據(jù)里可能含有數(shù)據(jù)為0的字節(jié),這樣的話,標準庫函數(shù)會提前結(jié)束而不會完成我們要求的操作。這個例程典型應(yīng)用于LCD數(shù)據(jù)的拷貝過程。根據(jù)不同的CPU,熟練使用相應(yīng)的嵌入?yún)R編,可以大大提高程序執(zhí)行的效率。
雖然是必殺技,但是如果輕易使用會付出慘重的代價。這是因為,使用了嵌入?yún)R編,便限制了程序的可移植性,使程序在不同平臺移植的過程中,臥虎藏龍,險象環(huán)生!同時該招數(shù)也與現(xiàn)代軟件工程的思想相違背,只有在迫不得已的情況下才可以采用。
今天分享到這里,大家有遇到什么問題可以向“傳智播客C/C++培訓(xùn)專家”留言哦!
第四篇:黑馬程序員c語言教程:Oracle簡介
9.通過子查詢建表 通過子查詢建表的例子
SQL>CREATE TABLE emp_41 AS SELECT id, last_name, userid, start_date FROM s_emp WHERE dept_id = 41;SQL> CREATE TABLE A as select * from B where 1=2;只要表的結(jié)構(gòu).10.用子查詢建表的注意事項
可以關(guān)連多個表及用集合函數(shù)生成新表,注意選擇出來的字段必須有合法的字段名稱,且不能重復(fù)。
用子查詢方式建立的表,只有非空NOT NULL的約束條件能繼承過來, 其它的約束條件和默認值都沒有繼承過來.根據(jù)需要,可以用alter table add constraint ……再建立其它的約束條件,如primary key等.11.Foreign Key的可選參數(shù)ON DELETE CASCADE 在創(chuàng)建Foreign Key時可以加可選參數(shù): ON DELETE CASCADE它的含義是如果刪除外鍵主表里的內(nèi)容,子表里相關(guān)的內(nèi)容將一起被刪除.如果沒有ON DELETE CASCADE參數(shù),子表里有內(nèi)容,父表里的主關(guān)鍵字記錄不能被刪除掉.12.如果數(shù)據(jù)庫表里有不滿足的記錄存在,建立約束條件將不會成功.13.給表創(chuàng)建和刪除同義詞的例子 SQL> CREATE SYNONYM d_sum 2 FOR dept_sum_vu;SQL> CREATE PUBLIC SYNONYM s_dept 2 FOR alice.s_dept;SQL> DROP SYNONYM s_dept;
十、ORACLE里的數(shù)據(jù)字典
1.什么是數(shù)據(jù)字典?ORACLE的數(shù)據(jù)字典是數(shù)據(jù)庫的重要組成部分之一,它隨著數(shù)據(jù)庫 的產(chǎn)生而產(chǎn)生, 隨著數(shù)據(jù)庫的變化而變化, 體現(xiàn)為sys用戶下所有的一些表和視圖.2.數(shù)據(jù)字典里存了以下內(nèi)容: 用戶信息
用戶的權(quán)限信息
所有數(shù)據(jù)對象信息表的約束條件統(tǒng)計分析數(shù)據(jù)庫的視圖等 不能手工修改數(shù)據(jù)字典里的信息.16
J2EE @ zxw 3.常用的數(shù)據(jù)字典
Dictionary 存放所有數(shù)據(jù)表,視圖,同義詞名稱和解釋 Dict_columns 數(shù)據(jù)字典里字段名稱的和解釋 Dba_users 用戶 Dba_tablespaces 表空間
Dba_data_files 數(shù)據(jù)庫的文件 Dba_free_space 空閑表空間 Dba_rollback_segs 回滾段
User_objects 數(shù)據(jù)對象 User_constraints 約束條件 User_sequences 序列號 User_views 視圖 User_indexes 索引 User_synonyms 同義詞
Session_roles 用戶的角色 User_role_privs 用戶的角色權(quán)限 User_sys_privs 用戶的系統(tǒng)權(quán)限 User_tab_privs 用戶的表級權(quán)限 V$session 實時用戶情況 V$sysstat 實時系統(tǒng)統(tǒng)計 V$sesstat 實時用戶統(tǒng)計 V$sgastat 實時SGA使用 V$locked_object 實時鎖 V$controlfile 控制文件 V$logfile 日志文件 V$parameter 參數(shù)文件 4.數(shù)據(jù)字典的分類 數(shù)據(jù)字典四大類別
User_ 用戶下所有數(shù)據(jù)庫對象
All_ 用戶權(quán)限范圍內(nèi)所有的數(shù)據(jù)庫對象 Dba_ 所有的數(shù)據(jù)庫對象
V$Content$nbsp;統(tǒng)計分析數(shù)據(jù)庫的視圖 賦于oem_monitor權(quán)限非DBA用戶也可查詢V$*視圖
5.查詢數(shù)據(jù)字典
SQL> select * from dictionary where instr(comments,'index')>0;SQL> select constraint_name, constraint_type, 2 search_condition, r_constraint_name 3 from user_constraints 4 where table_name = ‘&table_name';十一.控制數(shù)據(jù)、INSERT(往數(shù)據(jù)表里插入記錄的語句)SQL> insert into 表名(字段名1, 字段名2, ……)values(值1, 值2, ……);SQL> insert into 表名(字段名1, 字段名2, ……)select(字段名1, 字段名2, ……)from 另外的表名 where 條件;可以用&標記變量的方法多次輸入記錄
快速插入數(shù)據(jù)的方法, 一般用于大于128M的數(shù)據(jù)轉(zhuǎn)移 SQL> insert /*+ append */ into 表名
select * from 另外的用戶名.另外的表名 WHERE 條件;SQL> commit;注意事項:
用INSERT /*+ APPEND */ 的方法會對target_tablename產(chǎn)生級別為6的獨占鎖,如果運行此命令時還有對target_tablename的DML操作會排隊在它后面, 對OLTP系統(tǒng)在用的表操作是不合適的。17
J2EE @ zxw 2.插入字符串類型的字段的注意事項: 字符串類型的字段值必須用單引號括起來, 例如: ’GOOD DAY’
如果字段值里包含單引號’ 需要進行字符串轉(zhuǎn)換, 我們把它替換成兩個 單引號’ ’
字符串類型的字段值超過定義的長度會出錯, 最好在插入前進行長度校驗 ‘’ 標記是NULL, user 標明當前用戶
日期字段的字段值可以用當前數(shù)據(jù)庫的系統(tǒng)時間SYSDATE, 精確到秒
用字符串轉(zhuǎn)換成日期型函數(shù)TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC.年-月-日 小時:分鐘:秒 的格式Y(jié)YYY-MM-DD HH24:MI:SS NSERT時最大可操作的字符串長度小于等于4000個單字節(jié), 如果要插入更長的字符串, 請考慮字段用CLOB類型, 方法借用ORACLE里自帶的DBMS_LOB程序包.3、UPDATE(修改數(shù)據(jù)表里記錄的語句)SQL> UPDATE 表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 條件;如果修改的值N沒有賦值或定義時, 將把原來的記錄內(nèi)容清為NULL, 最好在修改前進行非空校驗;值N超過定義的長度會出錯, 最好在插入前進行長度校驗.新功能,可以修改子查詢后的結(jié)果集
例子:SQL> update(select * from s_dept)set id=50 where id=60;
4、DELETE(刪除數(shù)據(jù)表里記錄的語句)SQL> DELETE FROM 表名 WHERE 條件;注意:刪除記錄并不能釋放ORACLE里被占用的數(shù)據(jù)塊表空間.它只把那些 被刪除的數(shù)據(jù)塊標成unused.如果確實要刪除一個大表里的全部記錄, 可以用 TRUNCATE 命令, 它可以釋放占用的數(shù)據(jù)塊表空間
SQL> TRUNCATE TABLE 表名;此操作不可回退.5、SQL語句的分類 數(shù)據(jù)定義語言(DDL):create、alter、drop(創(chuàng)建、修改結(jié)構(gòu)、刪除)(其他:rename)數(shù)據(jù)操縱語言(DML):insert、delete、select、update(增、刪、查、改)(其他:truncate)
數(shù)據(jù)控制語言(DCL):grant、revoke(授權(quán)、回收)、set role 事務(wù)控制:commit、rollback、savepoint(其他:lock table、set constraint、set transaction)
審計控制:audit、noaudit 系統(tǒng)控制:alter system 會話控制:alter session 其他語句:comment(添加注釋)、explain plan、analyze、validate、call
6、ORACLE里事務(wù)控制 Commit 提交事務(wù) Rollback 回退事務(wù)
Savepoint 設(shè)置斷點, 在事務(wù)中標記位置, 事務(wù)結(jié)束, 斷點釋放
事務(wù)結(jié)束的情況遇到commit或者rollback遇到DDL和DCL語句發(fā)現(xiàn)錯誤,如死鎖用戶退出
SQL*PLUS系統(tǒng)重啟或崩潰 7.DML操作的注意事項 18
J2EE @ zxw 以上SQL語句對表都加上了行級鎖, 確認完成后, 必須加上事物處理結(jié)束的命令COMMIT 才能正式生效, 否則改變不一定寫入數(shù)據(jù)庫里.行級鎖也未能得到釋放.如果想撤回這些操作, 可以用命令 ROLLBACK 復(fù)原.在運行INSERT, DELETE 和 UPDATE 語句前最好估算一下可能操作的記錄范圍, 應(yīng)該把它限定在較小(一萬條記錄)范圍內(nèi),.否則ORACLE處理這個事物用到很大的回退段.程序響應(yīng)慢甚至失去響應(yīng).如果記錄數(shù)上十萬以上這些操作, 可以把這些SQL語句分段分次完成, 其間加上COMMIT 確認事物處理.太過頻繁的commit不好
第五篇:黑馬程序員c語言教程:DML語言強化
sql語言的類型
數(shù)據(jù)語言實現(xiàn)數(shù)據(jù)的crud
DML語句(Data Manipulation Language)數(shù)據(jù)庫操作語言
insert update delete select DDL語言 data definition Lanaguage
create table
create view index sequence synonym同義詞
truncate table DCL語言 data control language數(shù)據(jù)語言
commit rollback savetpointe
OCA認證 OCP(dba)一起考, 參加oracle的培訓(xùn) 2w Oracle數(shù)據(jù)庫管理員認證專員(OCA):Oracle Certified Associate Oracle數(shù)據(jù)庫管理員認證專家(OCP): Oracle Certified Professional Oracle數(shù)據(jù)庫管理員認證大師(OCM): Oracle Certified Master
語法: INSERT INTO table [(column [, column...])] VALUES(value [, value...]);
--1 向表中插入所有列
insert into emp values(1, 'tom_111', 'enginerr', 7839, sysdate, 5000, 100, 10)--2 向表中插入部分列
insert into emp(empno, ename, job, hiredate)values(2, 'tom_2222', 'enginerr', sysdate)
--3 隱式插入空值: 沒有寫出的列,默認為null值--4 顯示插入空值:--5 sql插入語言的地址符 & 取地址符后面相當于一個變量
mysql語言: preparedStatement語言 SQL> insert into emp(empno, ename, job, hiredate)values(&empno, &ename, &job, &hiredate);輸入 empno 的值: 3
輸入 ename 的值: 'tom_ccc' 輸入 job 的值: 'job' 輸入 hiredate 的值: '22-2月-81' 原值 1: insert into emp(empno, ename, job, hiredate)values(&empno, &ename, &job, &hiredate)新值 1: insert into emp(empno, ename, job, hiredate)values(3, 'tom_ccc', 'job', '22-2月-81')
&地址符, 可以在任何sql語言中使用.在select 語言中也可以使用地址符
SQL> select ename, job, &tt from emp;輸入 tt 的值: deptno 原值 1: select ename, job, &tt from emp 新值 1: select ename, job, deptno from emp
--7 批量插入數(shù)據(jù)--創(chuàng)建一張表
create table emp10 as
select * from emp where 1=2;--一次性的將emp中所有10號部門的員工插入到emp10中
--在insert語言中使用子查詢 子查詢 不光用在查詢套查詢, 也可用在DML語句套select語句
insert into emp10--列完全一樣,可以不寫
select * from emp where deptno=10;delete from emp10;
有關(guān)update更新語句
UPDATE table SET column = value [, column = value,...] [WHERE condition];--列子
SQL> update emp10 set sal=2300 where empno=7934;
有關(guān)刪除數(shù)據(jù)
DELETE [FROM] table [WHERE condition];
delete和truncate表區(qū)別
delete逐條刪除 truncate先摧毀表再重建delete語言是DML語言 truncate是DDL
DML語言可以閃回 做錯的并且提交了.可通過閃回,撤銷操作
DDL語言不可以閃回 flashback
delete是逐條刪除,會產(chǎn)生碎片, truncate不會產(chǎn)生碎片
行移動功能: 要開啟閃回功能,必須要開啟行移動功能delete不會釋放空間 truncate會delete可以回滾 truncate不可以
oracle delete快 mysql truncate快.實驗: 從文件中導(dǎo)入數(shù)據(jù), 通過命名delete 和 truncate刪除表數(shù)據(jù) 實驗
從文件中導(dǎo)入數(shù)據(jù)
SQL> set timing off;SQL> set feedback off;SQL> drop table testdelete purge;SQL> @c:Sql.sql;SQL> SQL> set timing on;//最后刪除數(shù)據(jù)表的時候,把時間打開,記錄時間
SQL> delete from testdelete;已用時間: 00: 00: 00.03
從文件中導(dǎo)入數(shù)據(jù)
SQL> set timing off;@c:Sql.sql;
set timing off;
select count(*)from testdelete;set timing on;//最后刪除數(shù)據(jù)表的時候,把時間打開,記錄時間
truncate table testdelete;已用時間: 00: 00: 00.39
事務(wù)基本概念
概念
一個或者多個DML語言組成特點
要么都成功,要么都失敗
特性
原子性 一致性 隔離性 持久性
事物的隔離性 多個客戶端同時操作數(shù)據(jù)庫的時, 要隔離他們的操作
否則:臟讀 不可重復(fù)讀 幻讀
設(shè)置不同的擱置級別來解決oracle中的事務(wù)
事務(wù)起始標志 DML語言(oracle默認事務(wù)似是打開的)2 事務(wù)的結(jié)束標志
提交: 顯示提交commit
隱式提交
1)執(zhí)行DDL語言
eg create table語言 還有I個隱式的功能
提交之前的沒有提交的DML語言(insert update)
2)正常退出
回滾: 顯示 rollback
隱式 掉電/宕機/非正常退出==系統(tǒng)出錯了 oracle事務(wù)控制--保存點
create table testsavepoint(tid number, tname varchar2(20));set feedback on
insert into testsavepoint values(1, 'tom1');insert into testsavepoint values(2, 'tom2');savepoint a;//創(chuàng)建一個保存點
insert into testsavepoint values(3, 'tom3a);rollback to savepoint a;
注意: 回退到savepoint a 前面插入的兩條sql語句還沒有提交;仍然還在一個事務(wù)里面;讓事務(wù)結(jié)束的方法 顯示 隱式 SQL> rollback / commit oracle數(shù)據(jù)的隔離級別問題
read only ,數(shù)據(jù)庫幾乎不做串行化操作,增加了read only SQL99