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