|
下面以在web應(yīng)用程序的工程目錄下的META-INFO中寫配置文件為例,配置數(shù)據(jù)庫連接池,用到的數(shù)據(jù)庫為MS Server 2000,驅(qū)動為jtds-1.2.jar,配置過程如下:
<%
Context initContext = new InitialContext();
Context envContext = (Context) initContext.lookup ("java:/comp/env");
DataSource db = (DataSource)envContext.lookup("jdbc/sql");
Connection conn = db.getConnection( );
out.print("ok");
conn.close();
%>
當(dāng)然還需要導(dǎo)入jar包:
<%@ page import="java.sql.*"%>
<%@ page import="javax.naming.*"%>
<%@ page import="javax.sql.*"%>
以上測試完全通過,表示數(shù)據(jù)庫連接池創(chuàng)建成功,僅已此文獻(xiàn)給那些初學(xué)者,快速上手!!
<家庭>
<人><大人>皮諾曹爸爸</大人></人>
</家庭>
(錯誤)
六。組合類型示例
<!ELEMENT 家庭 (人+, 家電*)>
<家庭>
<人 名字="郭大路" 性別="男" 年齡="25"/>
<人 名字="李尋歡" 性別="男" 年齡="38" 愛好="作個教育家和偉人"/>
<家電 名稱="彩電" 數(shù)量="3"/>
</家庭>
商業(yè)規(guī)則和業(yè)務(wù)邏輯可以通過程序存儲在oracle中,這個程序就是存儲過程。
存儲過程是SQL, PL/SQL, JAVA 語句的組合, 它使你能將執(zhí)行商業(yè)規(guī)則的代碼從從你的應(yīng)用程序中移動到數(shù)據(jù)庫。這樣的結(jié)果就是,代碼存儲一次但是能夠被多個程序使用。
要創(chuàng)建一個 過程對象(procedural object),必須有 CREATE PROCEDURE 系統(tǒng)權(quán)限。如果這個過程對象需要被其他的用戶schema 使用,那么你必須有 CREATE ANY PROCEDURE 權(quán)限。
執(zhí)行 procedure 的時候,可能需要excute權(quán)限。或者EXCUTE ANY PROCEDURE 權(quán)限。
如果單獨賦予權(quán)限,如下例所示: grant execute on MY_PROCEDURE to Jelly
調(diào)用一個存儲過程的例子: execute MY_PROCEDURE( 'ONE PARAMETER');
PROCEDURE 和 FUNCTION 的區(qū)別。 function有返回值,并且可以直接在Query中引用function和或者使用function的返回值。
PACKAGE 是function,procedure,variables 和sql 語句的組合。package允許多個procedure使用同一個變量和游標(biāo)。
創(chuàng)建 procedure的語法:
CREATE [ OR REPLACE ] PROCEDURE [ schema.]procedure
[(argument [IN | OUT | IN OUT ] [NO COPY] datatype
[, argument [IN | OUT | IN OUT ] [NO COPY] datatype]...
)]
[ authid { current_user | definer }]
{ is | as } { pl/sql_subprogram_body |
language { java name 'String' | c [ name, name] library lib_name
}]
可以使用 create or replace procedure 語句, 這個語句的用處在于,你之前賦予的excute權(quán)限都將被保留。
IN, OUT, IN OUT 用來修飾參數(shù)。IN 表示這個變量必須被調(diào)用者賦值然后傳入到PROCEDURE進(jìn)行處理。OUT 表示PRCEDURE 通過這個變量將值傳回給調(diào)用者。IN OUT 則是這兩種的組合。
authid代表兩種權(quán)限: 定義者權(quán)限(difiner right 默認(rèn)),執(zhí)行者權(quán)限(invoker right)。定義者權(quán)限說明這個procedure中涉及的表,視圖等對象所需要的權(quán)限只要定義者擁有權(quán)限的話就可以訪問。執(zhí)行者權(quán)限則需要調(diào)用這個procedure的用戶擁有相關(guān)表和對象的權(quán)限。
摘要: 閱讀全文 在這篇文章中,我將為大家介紹一種基于JSP且靈活有趣的技術(shù),那就是JSTL.JSTL全稱為 JAVA SERVER PAGES STANDARD TAG LIBRARY.雖然JSP已經(jīng)變的非常流行,但JSTL在基于SQL數(shù)據(jù)庫的簡單、快速的前后臺開發(fā)中還是沒有被廣泛的應(yīng)用。一旦你了解了JSTL,你就會了解到它的優(yōu)點,并發(fā)現(xiàn)在你作為程序員的日常工作中,它已經(jīng)被應(yīng)用到了很多方面。我這里假設(shè)你已經(jīng)熟悉HTML,能理解基本的SQL語句,和JSP的基礎(chǔ)知識。因為下面的內(nèi)容要涉及到這些知識。
JSTL是一個已經(jīng)被標(biāo)準(zhǔn)化的標(biāo)記庫集合,她支持迭代、條件、XML文檔的解析,國際化,和利用SQL與數(shù)據(jù)庫交互的功能。起初,JSTL規(guī)范一直由JCP (JAVA COMMUNITY PROCESS PROGRAM)組織下的JSR #52 發(fā)展完善,"JCP肩負(fù)著JAVA 技術(shù)發(fā)展的重任"--官方網(wǎng)站這樣評價。JCP作為一個開放性的組織,他同時吸收正式的會員和非正式會員.JCP對于JAVA技術(shù)規(guī)范的形成與發(fā)展發(fā)揮了重要的主導(dǎo)作用。 JSTL主要包括四個基本部分的標(biāo)記庫:CORE,XML,國際化,和對SQL的支持。由于這篇文章的主要是以其中的SQL部分的應(yīng)用來快速了解 JSTL,所以我們這篇文章只介紹了 CORE和SQL標(biāo)簽庫的一些基本功能。
這項技術(shù)簡單而且功能強(qiáng)大,足以和PHP、 COLDFUSION一較高下.他在拓展JAVA的應(yīng)用領(lǐng)域方面有足夠的能力,這些領(lǐng)域不只包括大型的可再升級的WEB應(yīng)用程序,對于僅擁有簡單主頁的 WEB程序一樣沒問題。這允許你在建立站點的時候可以避免那些經(jīng)??紤]的XML的集成和與數(shù)據(jù)庫的連接。正如我剛才提到的一樣,JSTL的關(guān)鍵點就是簡單易用。還有,那就是JSTL是基于JSP構(gòu)建的, 他允許我們使用所有的JAVA技術(shù),這一點我們有必要記住。
開始之前,我們需要弄清楚怎樣才能運(yùn)行JSTL.由于是基于JSP技術(shù)的,所以我們運(yùn)行它就需要一個能夠編譯JSP的容器,這里我們使用免費(fèi)的JSP容器:TOMCAT (HTTP://JAKARTA.APACHE.ORG/TOMCAT/INDEX.HTML).至于如何安裝這個產(chǎn)品已經(jīng)超出了本文所講述的范圍。毫無疑問,這個軟件產(chǎn)品現(xiàn)在已經(jīng)很普及了,而且關(guān)于如何安裝的文檔資料也是很多。這里假設(shè)您已經(jīng)安裝并成功配置了這個容器,你只需再安裝JSTL運(yùn)行所需文件即可,它可以從這里下載HTTP://JAKARTA.APACHE.ORG/TAGLIBS/DOC/STANDARD-DOC/INTRO.HTML 你不需要真正的安裝它,只需要將其中的.JAR文件包含到你的應(yīng)用程序的WEB-INF/LIB目錄下即可,稍后我會具體說到該怎么做.
因為我們要在一個支持標(biāo)準(zhǔn)SQL的數(shù)據(jù)庫上運(yùn)行程序,你需要在你的電腦上安裝有一個數(shù)據(jù)庫。數(shù)據(jù)庫的類型有許多種,這里我選擇了MYSQL。我之所以選擇他的原因在于首先,我們需要展示JSTL對于構(gòu)造簡單快速的應(yīng)用程序領(lǐng)域所起的作用,同時能和一直在這個領(lǐng)域處于主導(dǎo)地位的PHP+MYSQL有所比較;第二點那就是MYSQL是可以免費(fèi)下載并包含有一個針對JAVA的JDBC驅(qū)動.總之,為了使用下面的例子,你需要下載一個MYSQL服務(wù)器 (HTTP://WWW.MYSQL.COM/PRODUCTS/MYSQL/INDEX.HTML; MYSQL CONNECTOR/J JDBC驅(qū)動程序HTTP://WWW.MYSQL.COM/PRODUCTS/CONNECTOR-J/INDEX.HTML;還有就是 MYSQL CONTROL CENTER HTTP://WWW.MYSQL.COM/PRODUCTS/CONNECTOR-J/INDEX.HTML), 這個產(chǎn)品可以讓你非常容易的操作管理MYSQL數(shù)據(jù)庫文件。全部下載完成后,你需要安裝MYSQL和MYSQL CONTROL CENTER。另外還有就是MYSQL的JDBC驅(qū)動需要放到你的WEB應(yīng)用程序中的/WEB-INF/LIB目錄中。
在創(chuàng)建程序代碼之前,你需要創(chuàng)建并填寫數(shù)據(jù)庫表。關(guān)于這方面的主題文章也相當(dāng)廣泛,具體如何操作超出了本文的范圍。這里我推薦給你我們上面提及的一個可視化的管理工具 MYSQL CONTROL CENTER.你可以用他來創(chuàng)建一個用來運(yùn)行程序的測試用戶,數(shù)據(jù)庫以及創(chuàng)建一個測試表,并填寫若干記錄。關(guān)于登陸名及密碼 數(shù)據(jù)庫名稱這些配置環(huán)境參數(shù),你應(yīng)該記住他們,稍后需要應(yīng)用到我們的代碼中。
現(xiàn)在,你就可以準(zhǔn)備創(chuàng)建自己的第一個JSTL應(yīng)用程序了它需要我們做下面一些事情:
整個實例程序代碼包括兩個文件HELLO.JSP和 CONTINUE.JSP
HELLO.JSP文件允許你輸入數(shù)據(jù)庫名稱、登陸名稱、登陸密碼、數(shù)據(jù)庫表名。CONTINUE.JSP:接受HELLO.JSP中的數(shù)據(jù)信息并且連接數(shù)據(jù)庫,并對數(shù)據(jù)庫中的表執(zhí)行一個Select請求.
下面是這個系統(tǒng)所有的代碼文件,我將逐一進(jìn)行解釋。這些代碼相當(dāng)簡單,對于代碼的結(jié)構(gòu),我相信你即使沒有我的解釋你也能理解的.
1: <!-- HELLO.JSP -->
2: <HTML>
3: <HEAD>
4: <TITLE>HELLO</TITLE>
5: </HEAD>
6: <BODY BGCOLOR="#FFFFFF">
7: <H1>PLEASE, ENTER ALL NECESSARY INFORMATION AND CLICK OK.</H1>
8: <FORM METHOD="POST" ACTION="CONTINUE.JSP">
9: <BR>YOUR LOGIN TO DATABASE:
<INPUT TYPE="TEXT" NAME="LOGIN" SIZE="15">
10: <BR>YOUR PASSWORD TO DATABASE:
<INPUT TYPE="PASSWORD" NAME="PASSWORD" SIZE="15">
11: <BR>YOUR DATABASE NAME:
<INPUT TYPE="TEXT" NAME="DATABASE" SIZE="15">
12: <BR>YOUR DATABASE TABLE:
<INPUT TYPE="TEXT" NAME="TABLE" SIZE="15">
13: <BR><BR><INPUT TYPE="SUBMIT" NAME="SUBMIT" VALUE=" OK ">
14: </FORM>
15: </BODY>
16: </HTML>
(請注意文本左側(cè)的數(shù)字只是為你提供一些標(biāo)記信息,你不需要將他們輸入到你的代碼文件中。)
上面就是所有HELLO.JSP的源代碼,很驚奇吧,他僅僅是純粹的HTML代碼,就這么簡單,我想應(yīng)該沒有注釋的必要了.我之所以將這些代碼片段包含進(jìn)文章中就是為了展示一下JSTL集成到那些需要快速擴(kuò)充額外功能的HTML站點中是多么的簡單.讓我再為你展示一下CONTINUE.JSP的全部代碼,看過之后,你就會對 JSTL有些了解了。
1: <!-- CONTINUE.JSP -->
2: <%@ TAGLIB PREFIX="C" URI="HTTP://JAVA.SUN.COM/JSTL/CORE" %>
3: <@ TAGLIB PREFIX="SQL" URI="HTTP://JAVA.SUN.COM/JSTL/SQL" %>
4: <C:SET VAR="H" VALUE="LOCALHOST"/>
5: <C:SET VAR="L" VALUE="${PARAM.LOGIN}"/>
6: <C:SET VAR="P" VALUE="${PARAM.PASSWORD}"/>
7: <C:SET VAR="D" VALUE="${PARAM.DATABASE}"/>
8: <C:SET VAR="T" VALUE="${PARAM.TABLE}"/>
9: <HTML>
10: <HEAD>
11: <TITLE>CONTINUE</TITLE>
12: </HEAD>
13: <BODY BGCOLOR="#FFFFFF">
14: <SQL:SETDATASOURCE DRIVER="COM.MYSQL.JDBC.DRIVER"
URL="JDBC:MYSQL://${L}/${D}USER=${U}&PASSWORD=${P}"/>
15: <SQL:QUERY VAR="RESULT">
16: Select * FROM <C:OUT VALUE="${T}"/>
17: </SQL:QUERY>
18: <C:FOREACH VAR="ROW" ITEMS="${RESULT.ROWSBYINDEX}">
19: <C:OUT VALUE="${ROW[0]}"/> <BR>
20: </C:FOREACH>
21: </BODY>
22: </HTML>
(請注意文本左側(cè)的數(shù)字只是為你提供一些標(biāo)記信息,你不需要將他們輸入到你的代碼文件中。)
這就是我們所有的代碼了,是不是非常不錯?現(xiàn)在我門來解釋一下上面這些代碼的作用。
行1 是 HTML 的注釋說明。
行2--3 這些 JSP 標(biāo)簽是為了引用外部的 標(biāo)簽庫,更確切的說這里是引用了JSTL庫中的 CORE 和SQL標(biāo)簽庫部分。我們?yōu)樗麄兌荚O(shè)置了前綴名稱,以便于我們通過這些前綴名稱訪問被引入的標(biāo)簽庫中的功能方法。
行4---8正如 HELLO.JSP 真正運(yùn)行的樣子,他將請求CONTINUE.JSP,CONTINUE.JSP獲得請求后就需要得到并解析來自 HELLO.JSP的若干變量,我們使用了這樣的方式${PARAM.YOUR_VAR}。在第4行<C:SET標(biāo)簽,將變量${H}設(shè)置為 "LOCALHOST",第五行變量${L}將獲取我們在 HELLO.JSP中的LOGIN文本域中輸入的信息,第6,7,8行的變量將分別獲得來自 HELLO.JSP中用戶所輸入的密碼,數(shù)據(jù)庫名稱,數(shù)據(jù)表名稱。
行9--13是一些我經(jīng)常用來常見HTML網(wǎng)頁頭的簡單的HTML標(biāo)簽,馬上,重要的功能馬上要到了。
行14,我們試圖用我們先前獲得的MYSQL驅(qū)動程序(COM.MYSQL.JDBC.DRIVER)建立數(shù)據(jù)庫連接,在URL中,我們指明數(shù)據(jù)庫連接所需要的參數(shù),象數(shù)據(jù)庫名稱,主機(jī)名稱,登陸名及登陸密碼。依此,我們可以用其它任何的JDBC驅(qū)動程序連接其相對的數(shù)據(jù)庫。如果我們需要連接其他的 SQL數(shù)據(jù)庫,只需更改這個 URL就夠了。
行15--17 這里我們執(zhí)行了一個Select 查詢,請?zhí)貏e注意第16行,我們使用了另一個JSTL功能函數(shù)<C:OUT 用來輸出我們所獲取的數(shù)據(jù)表名稱,這里我們同樣可以使用其他的SQL命令,比如說 Insert,Delete, 等等。要執(zhí)行這些沒有返回值的查詢請求,你就需要使用<SQL:Update JSTL功能函數(shù)了。他可以直接執(zhí)行他們就象<SQL:QUERY一樣,只是執(zhí)行它是不需要特別指定結(jié)果變量來存儲語句執(zhí)行返回的結(jié)果。
行18--20 既然我們執(zhí)行了上面的Select查詢語句,我們就應(yīng)該把他的返回結(jié)果顯示出來。<C:FOREACH 就是JSTL 中一個具有迭代功能的函數(shù),執(zhí)行它時,我們通過$ {RESULT.ROWSBYINDEX}將返回的每一個數(shù)據(jù)行信息返回給變量${ROW},緊接著在第19行, 我們通過<C:OUT VALUE=" ${ROW[0]}"/>顯示返回的每個數(shù)據(jù)行的第一個數(shù)據(jù)列中的值。只要你的數(shù)據(jù)表中包含的字段,你都可以通過改變變量 ${ROW}中的數(shù)字大小來對請求表中的任意一個字段中的值對他們進(jìn)行訪問。
行21--22是HTML 頁腳
在你親自創(chuàng)建JSTL應(yīng)用程序過程中,可能你還沒有發(fā)現(xiàn)它有多么的強(qiáng)大,但你應(yīng)該能夠意識到JSTL的功能函數(shù)的簡單和高效性,試想有了JSTL,整合出一個基于SQL的新聞專欄是何等的快速,集成你現(xiàn)有的WEB站點是何等的容易。
很好,我們的代碼很容易理解的,即使一個非專業(yè)程序員的話,打個比方就算是一個設(shè)計師也能夠讀懂它,理解它,還可能進(jìn)行部分的修改,起碼是頁面布局上的修改。
該動作把指定文件插入正在生成的頁面。其語法如下:
<jsp:include page="relative URL" flush="true" />
前面已經(jīng)介紹過include指令,它是在JSP文件被轉(zhuǎn)換成Servlet的時候引入文件,而這里的jsp:include動作不同,插入文件的時間是在頁面被請求的時候。jsp:include動作的文件引入時間決定了它的效率要稍微差一點,而且被引用文件不能包含某些JSP代碼(例如不能設(shè)置HTTP頭),但它的靈活性卻要好得多。
例如,下面的JSP頁面把4則新聞?wù)迦胍粋€“What's New ?”頁面。改變新聞?wù)獣r只需改變這四個文件,而主JSP頁面卻可以不作修改:
WhatsNew.jsp
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE>What's New</TITLE>
</HEAD>
<BODY BGCOLOR="#FDF5E6" TEXT="#000000" LINK="#0000EE"
VLINK="#551A8B" ALINK="#FF0000">
<CENTER>
<TABLE BORDER=5 BGCOLOR="#EF8429">
<TR><TH CLASS="TITLE">
What's New at JspNews.com</TABLE>
</CENTER>
<P>
Here is a summary of our four most recent news stories:
<OL>
<LI><jsp:include page="news/Item1.html" flush="true"/>
<LI><jsp:include page="news/Item2.html" flush="true"/>
<LI><jsp:include page="news/Item3.html" flush="true"/>
<LI><jsp:include page="news/Item4.html" flush="true"/>
</OL>
</BODY>
</HTML>
Dojo是一款開源javascript工具包,它能夠幫助你在短時間內(nèi)構(gòu)建重量級的js應(yīng)用。它填補(bǔ)了js和各種瀏覽器之間運(yùn)行不是特別協(xié)調(diào)的問題,給予你強(qiáng)大、方便、輕量的性能,并且能夠提供構(gòu)建動態(tài)交互界面時的測試工具。
Dojo能夠讓你快速的部署標(biāo)準(zhǔn)的交互組件,動態(tài)變化和最強(qiáng)大簡單的AJax請求。這種能力是建立在最輕量級的打包規(guī)則(packaging system)之上的,因此你無需在記住哪個命令是出自哪個腳本文件的。
Dojo的打包規(guī)則和可選的構(gòu)造工具幫助你完成快速、優(yōu)化和透明的開發(fā)。Dojo也打包了一個易用的組件系統(tǒng)。
從配置模式看,Dojo的組件始終都是HTML和CSS的。
最重要的是,既然輕便的js是Dojo的核心,那么你的組件就能夠方便的用于HTML、SVG或者任何接下來可能出現(xiàn)的什么技術(shù)上。
網(wǎng)絡(luò)正在改變,dojo可以幫助你保持處于前列。Dojo讓你的網(wǎng)頁開發(fā)變得更好更容易更快速。
Dojo 是一個多平臺的 JavaScript 工具包。Dojo 之于 JavaScript 就如同 Java™ 運(yùn)行庫之于 Java 語言。目前 JavaScript 最大的應(yīng)用領(lǐng)域(也是 Dojo 的最大應(yīng)用領(lǐng)域)就是瀏覽器端的 Web 開發(fā)。
隨著最近圍繞 Web 2.0 和 Ajax 技術(shù)所展開的大肆宣揚(yáng),就連一些大型商業(yè)項目也已經(jīng)準(zhǔn)備開始實際嘗試基于 JavaScript 的應(yīng)用程序了。如果只考慮到從上世紀(jì) 90 年代末期(那時這類項目通常都會失?。┲两窦夹g(shù)的發(fā)展和變革,這樣做是一個不錯的主意。在過去 10 年中,JavaScript 虛擬機(jī)不斷成熟,瀏覽器的兼容性越來越好,一些兼容性標(biāo)準(zhǔn)不斷被完善,個人計算機(jī)上的 CPU 功率和內(nèi)存迅速增長,用戶也已經(jīng)累積了大量有關(guān)開發(fā) JavaScript 應(yīng)用程序的知識。Dojo 工具包似乎正處在將這些經(jīng)驗應(yīng)用到代碼中去的階段。
從概念上來說,Dojo 非常棒。它的一個引人注意之處是它為 JavaScript 開發(fā)帶來了高標(biāo)準(zhǔn)的質(zhì)量,似乎是受到了 Java 語言的啟迪。Dojo 從其他幾個 JavaScript 框架中發(fā)展而來這個事實可以確保它的基本概念已經(jīng)成熟。工具包 方法(與框架或庫方法相比)允許開發(fā)人員只在需要時使用 Dojo;在其他情況下,并不需要使用它。Dojo 的對業(yè)務(wù)友好的開源許可證也使得它對于各種項目來說都非常有吸引力。
Dojo提供了不同的構(gòu)建版本,把相關(guān)的部分構(gòu)成一個單一的壓縮文件。
不用擔(dān)心,無論你用的什么版本,都能夠毫無困難的調(diào)用Dojo提供的所有的API,只是你所選版本的相應(yīng)的庫將會優(yōu)先引導(dǎo)而已。