返回?cái)?shù)據(jù)庫總結(jié)目錄
什么是數(shù)據(jù)庫?
數(shù)據(jù)庫是存儲(chǔ)在一起的相關(guān)數(shù)據(jù)的集合,這些數(shù)據(jù)是結(jié)構(gòu)化的,無有害的或不必要的冗余,并為多種應(yīng)用服務(wù);數(shù)據(jù)的存儲(chǔ)獨(dú)立于使用它的程序;對(duì)數(shù)據(jù)庫插入新數(shù)據(jù),修改和檢索原有數(shù)據(jù)均能按一種公用的和可控制的方式進(jìn)行。當(dāng)某個(gè)系統(tǒng)中存在結(jié)構(gòu)上完全分開的若干個(gè)數(shù)據(jù)庫時(shí),則該系統(tǒng)包含一個(gè)“數(shù)據(jù)庫集合”。
什么是數(shù)據(jù)庫管理系統(tǒng)?
數(shù)據(jù)庫管理系統(tǒng)(Database Management System)是一種操縱和管理數(shù)據(jù)庫的大型軟件,是用于建立、使用和維護(hù)數(shù)據(jù)庫,簡稱DBMS。它對(duì)數(shù)據(jù)庫進(jìn)行統(tǒng)一的管理和控制,以保證數(shù)據(jù)庫的安全性和完整性。用戶通過DBMS訪問數(shù)據(jù)庫中的數(shù)據(jù),數(shù)據(jù)庫管理員也通過DBMS進(jìn)行數(shù)據(jù)庫的維護(hù)工作。它提供多種功能,可使多個(gè)應(yīng)用程序和用戶用不同的方法在同時(shí)或不同時(shí)刻去建立,修改和詢問數(shù)據(jù)庫。
按功能劃分,數(shù)據(jù)庫管理系統(tǒng)大致可分為6個(gè)部分:
(1)模式翻譯:提供數(shù)據(jù)定義語言(DDL)。用它書寫的數(shù)據(jù)庫模式被翻譯為內(nèi)部表示。數(shù)據(jù)庫的邏輯結(jié)構(gòu)、完整性約束和物理儲(chǔ)存結(jié)構(gòu)保存在內(nèi)部的數(shù)據(jù)字典中。數(shù)據(jù)庫的各種數(shù)據(jù)操作(如查找、修改、插入和刪除等)和數(shù)據(jù)庫的維護(hù)管理都是以數(shù)據(jù)庫模式為依據(jù)的。
(2)應(yīng)用程序的編譯:把包含著訪問數(shù)據(jù)庫語句的應(yīng)用程序,編譯成在DBMS支持下可運(yùn)行的目標(biāo)程序。
(3)交互式查詢:提供易使用的交互式查詢語言,如SQL。DBMS負(fù)責(zé)執(zhí)行查詢命令,并將查詢結(jié)果顯示在屏幕上。
(4)數(shù)據(jù)的組織與存取:提供數(shù)據(jù)在外圍儲(chǔ)存設(shè)備上的物理組織與存取方法。
⑸事務(wù)運(yùn)行管理:提供事務(wù)運(yùn)行管理及運(yùn)行日志,事務(wù)運(yùn)行的安全性監(jiān)控和數(shù)據(jù)完整性檢查,事務(wù)的并發(fā)控制及系統(tǒng)恢復(fù)等功能。
(6)數(shù)據(jù)庫的維護(hù):為數(shù)據(jù)庫管理員提供軟件支持,包括數(shù)據(jù)安全控制、完整性保障、數(shù)據(jù)庫備份、數(shù)據(jù)庫重組以及性能監(jiān)控等維護(hù)工具。
基于關(guān)系模型的數(shù)據(jù)庫管理系統(tǒng)已日臻完善,并已作為商品化軟件廣泛應(yīng)用于各行各業(yè)。它在各戶服務(wù)器結(jié)構(gòu)的分布式多用戶環(huán)境中的應(yīng)用,使數(shù)據(jù)庫系統(tǒng)的應(yīng)用進(jìn)一步擴(kuò)展。隨著新型數(shù)據(jù)模型及數(shù)據(jù)管理的實(shí)現(xiàn)技術(shù)的推進(jìn),可以預(yù)期DBMS軟件的性能還將更新和完善,應(yīng)用領(lǐng)域也將進(jìn)一步地拓寬。
數(shù)據(jù)庫總結(jié)
一.數(shù)據(jù)庫和數(shù)據(jù)庫管理系統(tǒng)
1.什么是數(shù)據(jù)庫?什么是數(shù)據(jù)庫管理系統(tǒng)?
2.關(guān)系型數(shù)據(jù)庫(范式)?
3.關(guān)系型數(shù)據(jù)庫管理系統(tǒng)
3.1.Oracle
3.2.MySQL
3.3.MS SQL Server
二.結(jié)構(gòu)化查詢語言(SQL)
1.數(shù)據(jù)定義語言(DDL) 用于創(chuàng)建、修改、刪除數(shù)據(jù)庫的數(shù)據(jù)結(jié)構(gòu)。
1.1數(shù)據(jù)庫
①創(chuàng)建數(shù)據(jù)庫
②連接數(shù)據(jù)庫
③刪除數(shù)據(jù)庫
1.2表
①創(chuàng)建表(臨時(shí)表,復(fù)制表)
②刪除表
③修改表結(jié)構(gòu),默認(rèn)值,自增長
④約束與數(shù)據(jù)完整性(主鍵,外鍵,非空,唯一,檢查)[添,刪,改]
1.3視圖
......
1.4
①索引
②序列
③觸發(fā)器
......
附A 數(shù)據(jù)類型
2.數(shù)據(jù)操作語言(DML) 于DDL不同的是,DML更關(guān)心的是存儲(chǔ)在數(shù)據(jù)庫中的數(shù)據(jù),而不是數(shù)據(jù)庫結(jié)構(gòu)本身。
2.1 添加數(shù)據(jù)
①簡單的單行插入
②多行插入
2.2更新數(shù)據(jù)
①簡單的更新數(shù)據(jù)
②Oracle中添加關(guān)鍵字returning
③Oracle中使用where current of 處理游標(biāo)
④MySQL中添加關(guān)鍵字limit
2.3刪除數(shù)據(jù)
①一般的Delete刪除數(shù)據(jù)
②使用truncate刪除數(shù)據(jù)
2.4獲取數(shù)據(jù)
2.4.1 簡單查詢 select <列A,列B> form <表名>;
2.4.2 表和列名注釋及別名
2.4.3 返回計(jì)算列(數(shù)學(xué)計(jì)算,字符串連接)
2.4.4 排序 order by
2.4.5 過濾
① where ( 連接運(yùn)算符[and,or],比較運(yùn)算符[= ,<>......],模式匹配[like,...],集合[in,botween])
② distinct使用
③限定行數(shù) (mysql[limit],oracle[rownum])
④ 處理null值
2.4.6 數(shù)據(jù)匯總(count , sum,avg,max,min...)
2.4.7 數(shù)據(jù)分組 group by
2.4.8 having使用(where先于聚合函數(shù)執(zhí)行,不能where中使用聚合函數(shù)做判斷,只能用having)
2.4.9 使用解析函數(shù)(mysql不支持,oracle支持)
2.4.10 組合查詢
......
2.4.11 多表查詢
......
2.5函數(shù)
2.6存儲(chǔ)過程
2.7事務(wù)
3數(shù)據(jù)控制語言(DCL) 代表SQL語句支持的另一種功能,控制對(duì)數(shù)據(jù)庫的訪問。
Eclipse .classpath文件淺談:
<classpathentry exported="true" kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
每個(gè)新建java工程(Project)都默認(rèn)存在的。
<classpathentry kind="src" output="km230/apitest/classes" path="km230/apitest/src"/>
指定源文件位置, 對(duì)應(yīng)工程屬性Java build path中Source項(xiàng)中的一項(xiàng), kind="src" 指明為源文件, 源文件路徑path, output為這條路徑中源文件編譯以后class文件的輸出路徑。
<classpathentry kind="src" path="km230batch/src"/>
指定源文件位置, 對(duì)應(yīng)工程屬性Java build path中Source項(xiàng)中的一項(xiàng), kind="src" 指明為源文件, 源文件路徑path, 編譯以后class文件的輸出路徑為默認(rèn)輸出路徑。
<classpathentry kind="output" path="km230server/approot/WEB-INF/classes"/>
指定編譯以后class文件的默認(rèn)輸出路徑, 對(duì)應(yīng)工程屬性Java build path中Source項(xiàng)中的default output path, kind="output"指明為默認(rèn)class輸出路徑, path為相應(yīng)輸出路徑。
注意: 這一條在文件中有且只能有一條(不可能同時(shí)出現(xiàn)兩個(gè)默認(rèn)吧?).
<classpathentry kind="lib" path="km230/lib/Notes.jar"/>
指定工程所用到的庫文件或目錄, 對(duì)應(yīng)工程屬性Java build path中Libraries項(xiàng)中的一項(xiàng), kind="lib"指明為庫文件或目錄, path為庫文件或目錄位置。
注意: 當(dāng)指定庫文件時(shí)(非庫目錄, 通常是jar包, 好像zip也可以, 不知道是否還有其它), 應(yīng)當(dāng)包含文件名。
<classpathentry kind="var" path="JUNIT_HOME/junit.jar" sourcepath="ECLIPSE_HOME/plugins/org.eclipse.jdt.source_3.0.0/src/org.junit_3.8.1/junitsrc.zip"/>
指定工程所用到的庫文件或目錄, 對(duì)應(yīng)工程屬性Java build path中Libraries項(xiàng)中的一項(xiàng), kind="var"指明帶有全局編譯路徑中設(shè)置的變量(Window->Prefrences->Java->Build Path->Classpath Variables), 如上面的ECLIPSE_HOME, path為這個(gè)變量目錄下的庫文件(同樣通常是jar包, 好像zip也可以, 也不知道是否還有其它)。
正則表達(dá)式 英文為:regular expression.
正則表達(dá)式的介紹:
正則表達(dá)式對(duì)象用來規(guī)范一個(gè)規(guī)范的表達(dá)式(也就是表達(dá)式符不符合特定的要求,比如是不是Email地址格式等),它具有用來檢查給出的字符串是否符合規(guī)則的屬性和方法。
除此之外,你用RegExp構(gòu)造器建立的個(gè)別正則表達(dá)式對(duì)象的屬性,就已經(jīng)預(yù)先定義好了正則表達(dá)式對(duì)象的靜態(tài)屬性,你可以隨時(shí)使用它們。
核心對(duì)象:
在Javascript 1.2, NES 3.0以上版本提供。
在Javascript 1.3以后版本增加了toSource方法。
建立方法:
文字格式或RegExp構(gòu)造器函數(shù)。
文字建立格式使用以下格式:
/pattern/flags即/模式/標(biāo)記
構(gòu)造器函數(shù)方法使用方法如下:
new RegExp("pattern"[, "flags"])即new RegExp("模式"[,"標(biāo)記"])
參數(shù):
pattern(模式)
表示正則表達(dá)式的文本
flags(標(biāo)記)
如果指定此項(xiàng),flags可以是下面值之一:
g: global match(全定匹配)
i: ignore case(忽略大小寫)
gi: both global match and ignore case(匹配所有可能的值,也忽略大小寫)
注意:文本格式中的參數(shù)不要使用引號(hào)標(biāo)記,而構(gòu)造器函數(shù)的參數(shù)則要使用引號(hào)標(biāo)記。所以下面的
表達(dá)式建立同樣的正則表達(dá)式:
/ab+c/i
new RegExp("ab+c", "i")
描述:
當(dāng)使用構(gòu)造函數(shù)的時(shí)候,必須使用正常的字符串避開規(guī)則(在字符串中加入前導(dǎo)字符\ )是必須的。
例如,下面的兩條語句是等價(jià)的:
re = new RegExp("\\w+")
re = /\w+/
下面的提供了在正則表達(dá)式中能夠使用的完整對(duì)特殊字符的一個(gè)完整的列表和描述。
正則表達(dá)式全部符號(hào)解釋
字符 |
描述 |
\ |
將下一個(gè)字符標(biāo)記為一個(gè)特殊字符、或一個(gè)原義字符、或一個(gè) 向后引用、或一個(gè)八進(jìn)制轉(zhuǎn)義符。例如,'n' 匹配字符 "n"。'\n' 匹配一個(gè)換行符。序列 '\\' 匹配 "\" 而 "\(" 則匹配 "("。 |
^ |
匹配輸入字符串的開始位置。如果設(shè)置了 RegExp 對(duì)象的 Multiline 屬性,^ 也匹配 '\n' 或 '\r' 之后的位置。 |
$ |
匹配輸入字符串的結(jié)束位置。如果設(shè)置了RegExp 對(duì)象的 Multiline 屬性,$ 也匹配 '\n' 或 '\r' 之前的位置。 |
* |
匹配前面的子表達(dá)式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。* 等價(jià)于{0,}。 |
+ |
匹配前面的子表達(dá)式一次或多次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等價(jià)于 {1,}。 |
? |
匹配前面的子表達(dá)式零次或一次。例如,"do(es)?" 可以匹配 "do" 或 "does" 中的"do" 。? 等價(jià)于 {0,1}。 |
{n} |
n 是一個(gè)非負(fù)整數(shù)。匹配確定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的兩個(gè) o。 |
{n,} |
n 是一個(gè)非負(fù)整數(shù)。至少匹配n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}' 等價(jià)于 'o+'。'o{0,}' 則等價(jià)于 'o*'。 |
{n,m} |
m 和 n 均為非負(fù)整數(shù),其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 將匹配 "fooooood" 中的前三個(gè) o。'o{0,1}' 等價(jià)于 'o?'。請(qǐng)注意在逗號(hào)和兩個(gè)數(shù)之間不能有空格。 |
? |
當(dāng)該字符緊跟在任何一個(gè)其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面時(shí),匹配模式是非貪婪的。非貪婪模式盡可能少的匹配所搜索的字符串,而默認(rèn)的貪婪模式則盡可能多的匹配所搜索的字符串。例如,對(duì)于字符串 "oooo",'o+?' 將匹配單個(gè) "o",而 'o+' 將匹配所有 'o'。 |
. |
匹配除 "\n" 之外的任何單個(gè)字符。要匹配包括 '\n' 在內(nèi)的任何字符,請(qǐng)使用象 '[.\n]' 的模式。 |
(pattern) |
匹配 pattern 并獲取這一匹配。所獲取的匹配可以從產(chǎn)生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中則使用 $0…$9 屬性。要匹配圓括號(hào)字符,請(qǐng)使用 '\(' 或 '\)'。 |
(?:pattern) |
匹配 pattern 但不獲取匹配結(jié)果,也就是說這是一個(gè)非獲取匹配,不進(jìn)行存儲(chǔ)供以后使用。這在使用 "或" 字符 (|) 來組合一個(gè)模式的各個(gè)部分是很有用。例如, 'industr(?:y|ies) 就是一個(gè)比 'industry|industries' 更簡略的表達(dá)式。 |
(?=pattern) |
正向預(yù)查,在任何匹配 pattern 的字符串開始處匹配查找字符串。這是一個(gè)非獲取匹配,也就是說,該匹配不需要獲取供以后使用。例如,'Windows (?=95|98|NT|2000)' 能匹配 "Windows 2000" 中的 "Windows" ,但不能匹配 "Windows 3.1" 中的 "Windows"。預(yù)查不消耗字符,也就是說,在一個(gè)匹配發(fā)生后,在最后一次匹配之后立即開始下一次匹配的搜索,而不是從包含預(yù)查的字符之后開始。 |
(?!pattern) |
負(fù)向預(yù)查,在任何不匹配 pattern 的字符串開始處匹配查找字符串。這是一個(gè)非獲取匹配,也就是說,該匹配不需要獲取供以后使用。例如'Windows (?!95|98|NT|2000)' 能匹配 "Windows 3.1" 中的 "Windows",但不能匹配 "Windows 2000" 中的 "Windows"。預(yù)查不消耗字符,也就是說,在一個(gè)匹配發(fā)生后,在最后一次匹配之后立即開始下一次匹配的搜索,而不是從包含預(yù)查的字符之后開始 |
x|y |
匹配 x 或 y。例如,'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 則匹配 "zood" 或 "food"。 |
[xyz] |
字符集合。匹配所包含的任意一個(gè)字符。例如, '[abc]' 可以匹配 "plain" 中的 'a'。 |
[^xyz] |
負(fù)值字符集合。匹配未包含的任意字符。例如, '[^abc]' 可以匹配 "plain" 中的'p'。 |
[a-z] |
字符范圍。匹配指定范圍內(nèi)的任意字符。例如,'[a-z]' 可以匹配 'a' 到 'z' 范圍內(nèi)的任意小寫字母字符。 |
[^a-z] |
負(fù)值字符范圍。匹配任何不在指定范圍內(nèi)的任意字符。例如,'[^a-z]' 可以匹配任何不在 'a' 到 'z' 范圍內(nèi)的任意字符。 |
\b |
匹配一個(gè)單詞邊界,也就是指單詞和空格間的位置。例如, 'er\b' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。 |
\B |
匹配非單詞邊界。'er\B' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。 |
\cx |
匹配由 x 指明的控制字符。例如, \cM 匹配一個(gè) Control-M 或回車符。x 的值必須為 A-Z 或 a-z 之一。否則,將 c 視為一個(gè)原義的 'c' 字符。 |
\d |
匹配一個(gè)數(shù)字字符。等價(jià)于 [0-9]。 |
\D |
匹配一個(gè)非數(shù)字字符。等價(jià)于 [^0-9]。 |
\f |
匹配一個(gè)換頁符。等價(jià)于 \x0c 和 \cL。 |
\n |
匹配一個(gè)換行符。等價(jià)于 \x0a 和 \cJ。 |
\r |
匹配一個(gè)回車符。等價(jià)于 \x0d 和 \cM。 |
\s |
匹配任何空白字符,包括空格、制表符、換頁符等等。等價(jià)于 [ \f\n\r\t\v]。 |
\S |
匹配任何非空白字符。等價(jià)于 [^ \f\n\r\t\v]。 |
\t |
匹配一個(gè)制表符。等價(jià)于 \x09 和 \cI。 |
\v |
匹配一個(gè)垂直制表符。等價(jià)于 \x0b 和 \cK。 |
\w |
匹配包括下劃線的任何單詞字符。等價(jià)于'[A-Za-z0-9_]'。 |
\W |
匹配任何非單詞字符。等價(jià)于 '[^A-Za-z0-9_]'。 |
\xn |
匹配 n,其中 n 為十六進(jìn)制轉(zhuǎn)義值。十六進(jìn)制轉(zhuǎn)義值必須為確定的兩個(gè)數(shù)字長。例如,'\x41' 匹配 "A"。'\x041' 則等價(jià)于 '\x04' & "1"。正則表達(dá)式中可以使用 ASCII 編碼。. |
\num |
匹配 num,其中 num 是一個(gè)正整數(shù)。對(duì)所獲取的匹配的引用。例如,'(.)\1' 匹配兩個(gè)連續(xù)的相同字符。 |
\n |
標(biāo)識(shí)一個(gè)八進(jìn)制轉(zhuǎn)義值或一個(gè)向后引用。如果 \n 之前至少 n 個(gè)獲取的子表達(dá)式,則 n 為向后引用。否則,如果 n 為八進(jìn)制數(shù)字 (0-7),則 n 為一個(gè)八進(jìn)制轉(zhuǎn)義值。 |
\nm |
標(biāo)識(shí)一個(gè)八進(jìn)制轉(zhuǎn)義值或一個(gè)向后引用。如果 \nm 之前至少有 nm 個(gè)獲得子表達(dá)式,則 nm 為向后引用。如果 \nm 之前至少有 n 個(gè)獲取,則 n 為一個(gè)后跟文字 m 的向后引用。如果前面的條件都不滿足,若 n 和 m 均為八進(jìn)制數(shù)字 (0-7),則 \nm 將匹配八進(jìn)制轉(zhuǎn)義值 nm。 |
\nml |
如果 n 為八進(jìn)制數(shù)字 (0-3),且 m 和 l 均為八進(jìn)制數(shù)字 (0-7),則匹配八進(jìn)制轉(zhuǎn)義值 nml。 |
\un |
匹配 n,其中 n 是一個(gè)用四個(gè)十六進(jìn)制數(shù)字表示的 Unicode 字符。例如, \u00A9 匹配版權(quán)符號(hào) (?)。 |
一些常用正則表達(dá)式收集:
2008-04-09
------------------------------------------
//匹配【整數(shù)】
var number=/^\d+$/;
//匹配【浮點(diǎn)數(shù)】
var floatNumber=/^((\d+)(\.\d{0,2})?)?$/;
//匹配【數(shù)字(包括整數(shù)和浮點(diǎn)數(shù))】
var number=/^(-?\d+)(\.\d+)?$/;
//匹配【Email】
var email=/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/;
//匹配【IP地址】
var ip=/^(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9])\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[0-9])$/;
//匹配【漢字】
var chinese=/[\u4e00-\u9fa5]/;
//匹配【URL】
var url=/(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$/;
//匹配【html標(biāo)記但不包括<img /> 】
var htmltag=/^<[^img][^>]*?[\\/]?>$/;
------------------------------
歡迎光臨: http://nine.freejsp.net/siyn或 http://www.siyn.org
http://www.freejsp.net/?id=siyn
HTML INPUT強(qiáng)制關(guān)閉輸入法 限定只能輸入英文或數(shù)字
< input name="input" style="ime-mode:disabled" >
如果所有表單元素都不想使用autocomplete功能呢?見下面的方法:
<form autocomplete = "off">
<input type="text" name="textfield">
</form>
摘要: 當(dāng)你使用Tomcat作為Web Server的時(shí)候,是不是會(huì)想過這樣的一個(gè)問題:如何利用Tomcat建立多個(gè)Web應(yīng)用 呢?
要實(shí)現(xiàn)這一點(diǎn)是很簡單的,也有多種方法。(以下說明使用%tomcat_home%代表Tomcat安裝目錄)。
閱讀全文
parseInt(string,10)
將字符串轉(zhuǎn)換為數(shù)字,
string待轉(zhuǎn)換的字符串
10表示十進(jìn)制(可選)
當(dāng)不填進(jìn)制參數(shù)是,默認(rèn)是十進(jìn)制,
但當(dāng)在前面有"0"時(shí),javascript的debugger會(huì)認(rèn)為這是一個(gè)八進(jìn)制數(shù),
如parseInt("09")返回值將為0應(yīng)為"09"不是一個(gè)合法的八進(jìn)制數(shù)
parseFloat(string)
將字符串轉(zhuǎn)換為浮點(diǎn)數(shù),
string待轉(zhuǎn)換的字符串
控制精度加.toFixed(3)
3為精度