- 狀態(tài)欄 (statusbar)顯功能
- 日期物件
- 隨數(shù)的產(chǎn)生
- 開啟新窗囗
范 例 5:
在 這 一 部 分 首 先 要 為 你 展 示 的 JavaScript 特 性 是 將 你 的 滑 鼠 移 到 這 個(gè) 不 同 顏 色
的連 結(jié)上 面, 此 時(shí) 看 看 瀏 覽 器 下 的 狀 態(tài) 列 有 何 結(jié) 果。 然 後 這 樣 的 功 能 我 們 可 以
與 JavaScript 的 功 能 相 結(jié) 合。 好, 現(xiàn) 在 再 將 你 的 滑 鼠 移 到 本 處 不 同 顏 色 的連 結(jié)上
面, 你 應(yīng) 該 會(huì) 發(fā) 現(xiàn) 有 一 個(gè) 視 窗 出 現(xiàn), 是 吧?! 如 何! 怎 麼 做 到 的 呢? 以 下 就 是
這 一 個(gè) 連 結(jié) 的 作 法:
<a href="tpage.htm" onMouseOver="window.status='Just another stupid link...'; return true">
在 這 兒 你 只 要 在 傳 統(tǒng) <a> 的 標(biāo) 簽 中 加 入 onMouseOver 的 method, 就 可 達(dá) 成 你 要 的
效 果 了。 這 里 的 window.status 是 用 來(lái) 讓 你 可 以 在 WWW 瀏 覽 器 的 狀 態(tài) 列 上 顯 示
一 些 訊 息 用 的。 在 語(yǔ) 法 中, 你 可 以 看 到 訊 息 部 分 是 用 ' 括 起 來(lái) 的 部 分, 而 非 以 " 括
起 來(lái), 在 訊 息 部 分 結(jié) 束 之 後, 必 須 加 上 ; return true。
好 了, 利 用 以 上 的 特 性 可 以 很 簡(jiǎn) 單 的 完 成 第 二 個(gè) 連 結(jié) 的 例 子! 相 當(dāng) 簡(jiǎn) 單, 以
onMouseOver 的 method 然 後 配 合 事 件 發(fā) 生 時(shí) 去 呼 叫 函 數(shù) hello() 就 行 了, 不 再
多 加 解 釋 了, 作 法 如 下:
<html>
<head>
<script language="LiveScript">
<!-- Hiding
function hello() {
alert("哈 羅!");
}
</script>
</head>
<body>
<a href="" onMouseOver="hello()">link</a>
</body>
</html>
范 例 6:
接 下 來(lái) 我 們 要 告 訴 你 一 個(gè) 使 用 日 期 和 時(shí) 間 的 例 子。 在 第 一 部 分 中, 你 已 看 過 了
lastModified 的 用 法 和 作 法。 現(xiàn) 在 要 告 訴 你 的 并 非 是 印 出 網(wǎng) 路 上 伺 服 器 或 文 件
修 改 日 期, 而 是 你 個(gè) 人 客 戶 端 機(jī) 器 的 日 期 和 時(shí) 間。 以 下 就 是 執(zhí) 行 結(jié) 果:
現(xiàn) 在 時(shí) 間 是: 14:4
今 天 日 期 為: 6/3/2008
做 法 如 下:
<script language="LiveScript">
<!-- Hiding
today = new Date()
document.write("現(xiàn) 在 時(shí) 間 是: ",today.getHours(),":",today.getMinutes())
document.write("<br>今 天 日 期 為: ", today.getMonth()+1,"/",today.getDate(),"/",today.getYear());
// end hiding contents -->
</script>
在 本 例 中, 我 們 必 需 首 先 建 立 一 個(gè) 日 期 變 數(shù), 這 可 以 由 today= new Date()來(lái) 完 成。
如 果 沒 有 特 別 指 定 時(shí) 間 與 日 期 的 話, 瀏 覽 器 將 會(huì) 采 用 本 地 客 戶 端 機(jī) 器 的 時(shí) 間, 若 將
它 放 入 變 數(shù) today 中。 這 兒 要 注 意 的 是: 我 們 并 沒 有 宣 告 today 這 個(gè) 變 數(shù) 的 型 態(tài),
這 和 Java 或 其 他 的 程 式 語(yǔ) 言 在 用 到 變 數(shù) 之 前 必 需 先 加 以 宣 告 的 方 式 有 相 當(dāng) 大 的 不
同。 在 完 成 today 的 日 期 變 數(shù) 後, 我 們 等 於 建 立 了 一 個(gè) 具 有 本 地 時(shí) 間 與 日 期 的 物 件
(object)。 接 著 就 可 以 使 用 get... 的 method 以 取 得 today 這 個(gè) 物 件 的 時(shí) 間 和 日 期。
請(qǐng) 注 意 getMonth 這 個(gè) method 所 取 得 的 月 份 范 圍 是 由 0~11, 所 以 必 須 加 1 以 代
表 真 正 的 1 月 至 12 月。 看 完 以 上 的 例 子 後, 想 想 你 可 以 使 你 的 文 件 變 得 有 點(diǎn)
智 慧, 例 如: 某 個(gè) 文 件 有 時(shí) 效 限 制 的 話, 你 可 以 利 用 我 們 在 上 一 部 份 的范 例 4
中 所 提 到 的 功 能 和 這 一 個(gè) 范 例 中 所 學(xué) 習(xí) 到 的 功 能, 設(shè) 計(jì) 一 個(gè) 讓 你 的 文 件 在 第10天
以 後 讀 到 的 話 就 會(huì) 告 訴 讀 者:"喂! 這 篇 已 過 時(shí) 了!"的 程 式, 試 試 看, 并 不 難!
除 以 上 功 能 外, 在 建 立 日 期 物 件 時(shí) 你 也 可 以 事 先 設(shè) 定 日 期 如 下:
docStarted= new Date(96,0,13)
首 先 是 年(西 元), 接 著 是 月(但 記 得 減 1), 再 接 著 是 日。 同 樣 的 方 法 也 可 以
加 上 時(shí) 間 的 設(shè) 定, 如 下:
docStarted = new Date(96,0,13,10,50,0)
前 三 個(gè) 是 日 期 的 年、 月、 日, 接 著 是 時(shí)、 分、 秒。 最 後, 我 們 必 須 提 醒 你,
JavaScript 并 沒 有 實(shí) 際 的 日 期 型 態(tài), 但 是 它 卻 能 毫 不 費(fèi) 力 地 顯 示 出 日 期 和 時(shí) 間,
原 因 是 它 是 從 1 / 1 / 1970 0:0h 開 始 以 ms(milli seconds) 來(lái) 計(jì) 算 目 前 的 時(shí) 間 的,
這 聽 起 來(lái) 似 有 些 復(fù) 雜, 但 你 倒 不 用 擔(dān) 心, 它 有 標(biāo) 準(zhǔn) 的 共 用 函 數(shù) 可 以 計(jì) 算,
你 只 要 知 道 如 何 用 就 可 以 了!
范 例 7:
接 下 來(lái) 我 們 要 為 你 介 紹 一 個(gè) 可 以 產(chǎn) 生 亂 數(shù) 的 函 數(shù), 也 是 以 JavaScript 所 寫 的。
這 個(gè) 函 數(shù) 只 是 利 用 了 一 點(diǎn) 小 技 巧 而 已, 而 這 種 技 巧 在 大 部 分 的 編 譯 器(compiler)中,
大 都 是 如 此(或 類 似) 計(jì) 算 出 亂 數(shù) 來(lái) 的。 我 相 信 JavaScript 最 後 應(yīng) 也 會(huì) 以 相 似 的 方
法 來(lái) 產(chǎn) 生 這 樣 的 method , 如 果 它 會(huì) 提 供 這 樣 功 能 的 話。 以 下 是 此 函 數(shù) 的 結(jié) 果:
這 是 一 個(gè) 計(jì) 算 產(chǎn) 生 的 亂 數(shù): 0.9836312285070992
以 下 是 這 個(gè) 作 法 的 寫 法:
<html>
<head>
<script language="LiveScript">
function RandomNumber() {
today = new Date();
num = Math.abs(Math.sin(today.getTime()));
return num;
}
</script>
</head>
<body>
<script language="LiveScript">
<!--
document.write("This is a random number:", RandomNumber());
// -->
</script>
</body>
</html>
我 們 的 做 法 是 以 上 一 個(gè) 范 例 中 的 時(shí) 間 函 數(shù); 它 會(huì) 出 現(xiàn) 一 個(gè) 很 大 的 數(shù),
利 用 這 個(gè) 數(shù) 再 加 以 運(yùn) 算 即 可! 例 如: 將 它 拿 來(lái) 做 正 弦 函 數(shù)(sin) 的 運(yùn)
算, 得 到 的 數(shù) 再 做 絕 對(duì) 值 的 運(yùn) 算, 結(jié) 果 可 以 得 到 一 個(gè) 介 於 0 與 1 間 的
實(shí) 數(shù)。 因 為 時(shí) 間 的 改 變 是 ms 為 單 位, 而 且 你 絕 不 會(huì) 獲 得 相 同 的 數(shù) 字。
不 過 這 個(gè) 做 法 并 不 適 合 拿 來(lái) 快 速 的 連 續(xù) 產(chǎn) 生 一 系 列 的 亂 數(shù), 但 如 果 你
是 不 定 時(shí), 久 久 的 用 一 次, 那 效 果 就 不 錯(cuò) 了!
范 例 8:
JavaScript 的 一 個(gè) 重 要 特 點(diǎn) 是 它 可 以 制 作 視 窗。 你 可 以 產(chǎn) 生 一 個(gè) 的 視 窗, 并 且
在 此 視 窗 中 載 入 HTML 文 件, 完 全 以 JavaScript 來(lái) 航 游 網(wǎng) 際 網(wǎng) 路(Internet )。
接 下 來(lái) 的 范 例 就 是 告 訴 你 如 何 開 啟 一 個(gè) 視 窗 并 且 寫 點(diǎn) 東 西 進(jìn) 去, 你 可 先 試 試
按 一 下 范 中 之 接 鈕 看 看!
原 始 程 式 如 下:
<html>
<head>
<script language="LiveScript">
function WinOpen() {
msg=open("","DisplayWindow","toolbar=no,directories=no,menubar=no");
msg.document.write("<HEAD><TITLE>哈 羅!</TITLE></HEAD>");
msg.document.write("<CENTER><H1>酷 斃 了!</H1><h2>這 是<B>JavaScript</B>所 開 的 視 窗!</h2></CENTER>");
}
</script>
</head>
<body>
<form>
<input type="button" name="Button1" value="Push me" onclick="WinOpen()">
</form>
</body>
</html>
這 兒 你 又 看 到 用 按 鈕 來(lái) 啟 動(dòng) 函 數(shù)。 這 次 的 函 數(shù) WinOpen()是 藉 著 一 個(gè) open
的 method 來(lái) 產(chǎn) 生 一 個(gè) 新 的 視 窗。 第 一 對(duì) 雙 引 號(hào)("")是 用 來(lái) 描 述 欲 載 入 至 視 窗
中 的 文 件 URL 位 置。 如 果 留 者 空 白 的 話, 那 就 會(huì) 呈 現(xiàn) 一 個(gè) 空 白 視 窗, 并 可 以
透 過 JavaScript 寫 入 東 西! 下 一 對(duì) 雙 引 號(hào) 內(nèi) 的 內(nèi) 容 是 這 個(gè) 新 開 啟 視 窗 的 名 字,
你 可 以 喜 歡 給 它 任 意 一 個(gè) 名 字, 但 不 可 加 入 空 白, 如 用 Display Window 的 話 便
會(huì) 出 現(xiàn) 錯(cuò) 誤 訊 息, 請(qǐng) 注 意。 接 下 來(lái) 的 一 連 串 雙 引 號(hào) 內(nèi) 所 指 定 的 是 該 視 窗
的 相 關(guān) 性 質(zhì)(properties), 這 些 蠻 有 趣 的, 你 可 以 指 定 要 不 要 有 工 具 棒(toolbar) 、
卷 軸(scrollbar), 等 等, 例 如: 如 果 你 寫 toolbar = yes, 那 就 會(huì) 在 你 所 產(chǎn) 生 出
來(lái) 的 視 窗 中 出 現(xiàn) 一 排 工 具 列。 以 下 有 許 多 你 可 以 改 變 的 視 窗 特 性, 請(qǐng) 注 意 它 們
字 中 間 不 可 以 有 空 白:
toolbar
location
directories
status
menubar
scrollbars
resizable
copyhistory
width=pixels
height=pixels
以 上 的 pixels 部 分, 你 可 以 填 入 點(diǎn) 數(shù) 的 數(shù) 值, 這 數(shù) 值 是 告 訴 瀏 覽 器 這 個(gè) 視 窗 的
大 小。 在 開 啟 視 窗, 并 且 將 它 稱 為 msg 以 後, 就 可 以 開 始 寫 些 東 西 到 視 窗 中 了。
你 可 以 寫 入 一 般 正 規(guī) 的 HTML 語(yǔ) 法 文 字。 哇! 這 可 不 得 了 了, 也 就 是 說(shuō), 你 可 以
利 用 先 前 使 用 者 在 form 表 格 中 輸 入 給 你 的 文 章 直 接 將 它 回 應(yīng) 至 瀏 覽 器 上 來(lái) 了! 這 些
功 能 在 幾 個(gè) 月 前 大 概 還 只 能 用 CGI 才 能 達(dá) 到 喔! 現(xiàn) 在 你 不 用 CGI 也 可 以 做 了!
- 什麼是JavaScript?
- 執(zhí)行 JavaScript scripts
- 將scripts 語(yǔ)法嵌入HTML文件之中
- 第一個(gè)函數(shù)
- 輸入型元件
- 日期功能 -- 最後修改期
JavaScript 是一種新的描述語(yǔ)言,此一語(yǔ)言可以被箝入 HTML 的文件之中。
透過 JavaScript 可以做到回應(yīng)使用者的需求事件 (如: form 的輸入) 而不用任何的網(wǎng)路
來(lái)回傳輸資料,所以當(dāng)一位使用者輸入一項(xiàng)資料時(shí),它不用經(jīng)過傳給伺服端 (server)
處理,再傳回來(lái)的過程,而直接可以被客戶端 (client) 的應(yīng)用程式所處理。你也可
以想像成有一個(gè)可執(zhí)行程式在你的客端上執(zhí)行一樣!目前已有一些寫好的程式在
Internet 上你可以連過去看看,以下有一些計(jì)算器的例子,在 Nescape 上。
JavaScript 和 Java 很類似,但到底并不一樣! Java 是一種比 JavaScript 更復(fù)雜
許多的程式語(yǔ)言,而 JavaScript 則是相當(dāng)容易了解的語(yǔ)言。JavaScript 創(chuàng)作者
可以不那麼注重程式技巧,所以許多 Java 的特性在 Java Script 中并不支援。
如需相關(guān)的更多資訊,可以去讀讀 Netscape 的有關(guān) Netscape JavaScript 之介紹。
JavaScript 如何執(zhí)行呢?
Netscape 2.0 beta 3 版以上,就可以執(zhí)行 JavaScript 的功能了,我們測(cè)試過至少
beta 3 版以上可以,其他種類的 WWW 瀏覽器如:Internet Expore 3.0也有此一功能。
以下我們就以一些例子來(lái)告訴你如何將 JavaScript 寫在 HTML 文件中,并且體會(huì)
一下新語(yǔ)言的特性,我們從第一個(gè)例子開始:如何用 JavaScript 印出一串文字至
HTML 文件中:
<html>
<head>
My first JavaScript!
</head>
<body>
<br>
This is a normal HTML document.
<br>
<script language="LiveScript">
document.write("這是以 JavaScript 印出的!")
</script>
<br>
Back in HTML again.
</body>
</html>
如果你使用的 WWW 瀏覽器是 Netscape 2.0 beta 3 以上版本的話,那你就可以
看到相關(guān)的結(jié)果,而如果你的瀏覽器并非是可以支援 JavaScript 的話,那看起
來(lái)就會(huì)有一些怪怪的了,以上范例的結(jié)果如下:
This is a normal HTML document.
這是以 JavaScript 印出的!
Back in HTML again. 此一范例并沒有太大的用處,它只是要告訴你如何使用<script>的標(biāo)簽,并
如何將它置於 HTML 的文件之中而已,這個(gè)新的標(biāo)簽?zāi)憧梢蕴厮旁谖募?/span>
中的任何地方。
范例 2:
接下來(lái)下一個(gè)例子所要介紹的是有關(guān)函數(shù) (function) 的使用。請(qǐng)放心,函數(shù)并
非很難懂的東西,但它卻相當(dāng)有用。函數(shù)通常是在 HTML 文件中 <body >的
部份被呼叫,而理所當(dāng)然地,它最好事先被宣告并放在 HTML 文件中 <body>
的部份。好讓在 <body> 部分中使用到函數(shù)時(shí),它已確定被讀取住來(lái)。另外,
<script> 標(biāo)簽的有關(guān)描述語(yǔ)法剖份,你可以用注解的符號(hào)將它括起來(lái),以免舊
版或無(wú)法讀取 JavaScript 的瀏覽器讀到,而誤會(huì)了意思!
<html>
<head>
<script language="LiveScript">
function pushbutton() {
alert("嗨! 你好");
}
</script>
</head>
<body>
<form>
<input type="button" name="Button1" value="Push me" onclick="pushbutton()">
</form>
</body>
</html>
如果你是使用 Netscape 2.0 beta 3 以上的瀏覽器,那以上 JavaScript 語(yǔ)法部份
的結(jié)果如下,你可以試著按按鈕看看有何結(jié)果產(chǎn)生!
在范例 2 中,將會(huì)產(chǎn)生一個(gè)按鈕,當(dāng)你用滑鼠去按它的時(shí)候,應(yīng)該會(huì)出現(xiàn)
一個(gè)視窗上面有“嗨! 你好”的字串,如何?不錯(cuò)吧!這個(gè)結(jié)果是如何產(chǎn)生
的呢?首先,在 <head>內(nèi)的函數(shù)會(huì)被載入并存於內(nèi)存中,接著一個(gè)新
的 <form>標(biāo)簽 <input type ="button".....>將產(chǎn)生一個(gè)接鈕。然後,你可以
在後面看到 'onClick' 的指令,這就是告訴瀏覽器,當(dāng)該按鈕被按時(shí),應(yīng)會(huì)執(zhí)行
onClick 後的函數(shù) 'pushbutton()',而這個(gè)函數(shù)在剛剛程式被載入時(shí)就已安放在
記憶體中了!請(qǐng)注意,在這個(gè)函數(shù)中我們用到了個(gè)新東西- alert 的 method,
是 JavaScript 事先定義好的,它會(huì)以對(duì)話視窗產(chǎn)生內(nèi)涵的訊息,并有一"確定"
(OK)的按鈕。 JavaScript 定義了許多的 method,你可以連至 Netscape 公司去
獲取較完整的訊息。我想這些 method 在不久的將來(lái)會(huì)有長(zhǎng)長(zhǎng)的一串可以夠你
學(xué)的,不過目前的 method 也已經(jīng)可以做出相當(dāng)多東西了!
接著下個(gè)例子將告訴你如何由一個(gè)輸入型表格中讀入使用者的輸入資料,
事實(shí)上,這也是加入個(gè)函數(shù)就可以達(dá)成的。
范例 3:
<html>
<head>
<script language="LiveScript">
<!-- hide script from old browsers
function getname(str) {
alert("哈羅! "+ str+"!");
}
// end hiding contents -->
</script>
</head>
<body>
Please enter your name:
<form>
<input type="text" name="name" onBlur="getname(this.value)" value="">
</form>
</body>
</html>
現(xiàn)在你可以試試結(jié)果如何:
請(qǐng)輸入你的名字:
(<!- ... ->) 此部分即我們之前所提到的它可以避免舊版本或是不支援 JavaScript
的 WWW 瀏覽器因?yàn)椴徽J(rèn)識(shí)這些函數(shù)而產(chǎn)生錯(cuò)誤。它的順序應(yīng) 該為 <script>
先,接著為注解的開頭 <!-,然後是內(nèi)容,注解尾 ->, 最後是 </script>。
另外要注意的一點(diǎn)是,語(yǔ)解尾那一行的開頭雙斜線 "http://" ,不可以省略,它代表了
JavaScript 的注解,若省略了的話, ->之前的字會(huì)被誤認(rèn)為是 JavaScript 的指令。
這個(gè)例子可以讓使用者輸入一段文字,然後再輸入完畢後經(jīng)由 <input>標(biāo)簽中的
"onBlur" 事件函數(shù)偵知,於是呼叫 Getname(Str)這個(gè)函數(shù)來(lái)加以取得輸入字串,
并將它顯示在對(duì)話視窗上!函數(shù) Getname(this.value) 中的 "this.value" 是你在文
字輸入格式中所輸入的值。
范例 4::
這個(gè)范例更是帥了!我們?cè)?HTML 文件檔完成了以後,常會(huì)加上一行文件
最後修改的日期,現(xiàn)在你可不用擔(dān)心每次都要去改或是忘了改了。你可以
很簡(jiǎn)單的寫一個(gè)如下的描述語(yǔ)法程式,就可以自動(dòng)的為你每次產(chǎn)生最後修
改的日期了:
<html>
<body>
This is a simple HTML- page.
<br>
Last changes:
<script language="LiveScript">
<!-- hide script from old browsers
document.write(document.lastModified)
// end hiding contents -->
</script>
</body>
</html>
以上的 document.lastModified 叁數(shù)在 Netscape 2.0 beta 2 版時(shí)是被寫成
documeut.lastmodified 的,然而,之後的版本就改為 document.lastModified,
所以注意一下 ;JavaScript 本身是會(huì)區(qū)分大小寫的, lastmodified 與 lastModified
在它看來(lái)是不同的結(jié)果。
最後,在這一部分結(jié)束之前,要提醒你一點(diǎn),像范例 4 ,的用法并非每一部
機(jī)器都是一樣的,例如:PC 上跑得很正確的,在工作站上不一定會(huì)有相同的
結(jié)果,所以,或許你仍得測(cè)一測(cè)不同機(jī)器的結(jié)果才會(huì)有所定論。當(dāng)然,這一切
是因?yàn)?JavaScript 還正在發(fā)展的原因,最新的訊息還是得去拜訪一下Netscape
公司才知道。也許你也不用奇怪,當(dāng)你隔周再來(lái)訪時(shí),JavaScript 可能又作了
相當(dāng)大的改變了呢
在這個(gè)例子中又有新的東西了。首先,讓我們注意一下,在語(yǔ)法中的注解部分
開發(fā)的朋友,在操作數(shù)據(jù)庫(kù)的時(shí)候,相信絕大部分人都用過它。但它不僅僅就是一個(gè)結(jié)果集的純載體,僅僅只有存儲(chǔ)的功能。下面就簡(jiǎn)略說(shuō)一下它的功能。
結(jié)果集大體上可以分為四類,它們各有特點(diǎn),基本上都和Statement語(yǔ)句的創(chuàng)建方式有關(guān)。
1、基本型(最基本,用得最廣泛)
創(chuàng)建方式:無(wú)參數(shù)創(chuàng)建型
Statement st = conn.CreateStatement
ResultSet rs = Statement.excuteQuery(sqlStr);
特點(diǎn):這種最簡(jiǎn)單,沒有特別的功能(不支持滾動(dòng)、更新等等),只能用next()逐個(gè)單方向去讀取數(shù)據(jù)。
2、滾動(dòng)型
創(chuàng)建方式:參數(shù)創(chuàng)建型
Statement st = conn.createStatement(int resultSetType, int resultSetConcurrency)
ResultSet rs = st.executeQuery(sqlStr)
參數(shù):
resultSetType是設(shè)置ResultSet對(duì)象的類型可滾動(dòng)
resultSetConcurency是設(shè)置ResultSet對(duì)象能夠修改的
具體的參數(shù)值見ResultSet.
特點(diǎn):(和具體參數(shù)的設(shè)置有關(guān)。)這種類型支持滾動(dòng)獲取記錄,可以向前向后操作,類似于分頁(yè)功能的操作方式。如支持:next()、previous()、first()、absolute(int n)等等。
3、更新型
創(chuàng)建方式:(和2一樣,不過參數(shù)選取不同)
Statement st = createstatement(Result.TYPE_SCROLL_INSENSITIVE,Result.CONCUR_UPDATABLE)
特點(diǎn):可以完成對(duì)數(shù)據(jù)庫(kù)的更新操作。更新的方法是,把ResultSet的游標(biāo)移動(dòng)到你要更新的行,然后調(diào)用updateXXX(),再用updateRow()完成對(duì)數(shù)據(jù)庫(kù)的寫入。
限制/要求:(1)對(duì)單表操作。(2)不包含join或者group by子句。
4、保持型
創(chuàng)建方式:
Statement st=createStatement(int resultsetscrollable,int resultsetupdateable,int resultsetSetHoldability)
ResultSet rs = st.excuteQuery(sqlStr);
參數(shù):只介紹第三個(gè)resultsetSetHoldability,表示在結(jié)果集提交后結(jié)果集是否打開,其值為
ResultSet.HOLD_CURSORS_OVER_COMMIT:表示修改提交時(shí),不關(guān)閉數(shù)據(jù)庫(kù)。
ResultSet.CLOSE_CURSORS_AT_COMMIT:表示修改提交時(shí)ResultSet關(guān)閉
特點(diǎn):一般情況下,在使用Statement執(zhí)行完一個(gè)查詢,又去執(zhí)行另一個(gè)查詢的時(shí)候,第一個(gè)查詢的結(jié)果集就會(huì)被關(guān)閉。該方式可以自由設(shè)定是否關(guān)閉結(jié)果集。
限制/要求:(1)只是在JDBC3.0的驅(qū)動(dòng)下才能成立。
可更新的結(jié)果集:
更新一行:
UpdateXXX()è cancelRowUpdates()èupdateRow()èrowUpdated()。
UpadateXXX()方法只能修改當(dāng)前行的數(shù)據(jù),并不能修改數(shù)據(jù)庫(kù)中的數(shù)據(jù),所以在調(diào)用updateXXX()后,還要調(diào)用updateRow()方法,用當(dāng)前行中的新數(shù)據(jù)更新數(shù)據(jù)庫(kù)。
CancelRowUpdates()方法用來(lái)放棄對(duì)當(dāng)前行的修改,注意,要讓這個(gè)方法有效,必須在調(diào)用updteRow()方法之前調(diào)用它。
rowUpdated()方法來(lái)判斷當(dāng)前行是否被更新。
插入行:
moveToInsertRow()方法移動(dòng)游標(biāo)到插入行,插入行是一個(gè)與可更新的結(jié)果集相聯(lián)系的特殊的緩存行。
moveToInsertRow()èupdateXXX()ègetXXX()èinsertRow()èrowInserted()
insertRow()將新行傳遞給數(shù)據(jù)庫(kù),從而在新數(shù)據(jù)庫(kù)中真正插入一行數(shù)據(jù)
rowInserted()方法來(lái)判斷當(dāng)前行是否是插入行。
刪除一行:
deletRow()從結(jié)果集中和數(shù)據(jù)庫(kù)中刪除一行,當(dāng)游標(biāo)指向插入行的時(shí)候,不能調(diào)用這個(gè)方法。一個(gè)被刪除的行可能在結(jié)果集中留下一個(gè)空的位置,可以調(diào)用 rowDeleted()方法來(lái)判斷一行是否被刪除。
可更新結(jié)果集的使用必須滿足下面3個(gè)條件:
1, 只能是針對(duì)數(shù)據(jù)庫(kù)中單張表單的查詢
2, 查詢語(yǔ)句中不能包含任何的join操作。
3, 查詢操作的表中必須有主鍵,而且在查詢的結(jié)果集中必須包含作為主鍵的字段。
結(jié)果集中執(zhí)行插入操作,還應(yīng)該滿足下面兩個(gè)條件
1, 查詢操作必須選擇數(shù)據(jù)庫(kù)表中所有不能為空的列
2, 查詢操作必須選擇所有沒有默認(rèn)值的列。
判斷ResultSet是否為空
ResultSet rs=stmt.executeQuery(sql);
rs == null;
rs.size()這個(gè)方法沒有的
rs為ResultSet的引用,即使結(jié)果集里有0條記錄,rs也不為空,所以用rs == null來(lái)判斷結(jié)果集里是否有0條記錄是錯(cuò)誤的,而要用 rs.getRow(); 為0則表示沒有記錄--使用的時(shí)候也有問題
使用rs.next()是否為true來(lái)判斷,會(huì)使游標(biāo)前移一位,可能丟掉一條記錄,不合適
boolean hasRows = false;
下面的方法較合適
while (rs.next()){
hasRows = true;
//Do your stuff
}
if (!hasRows ){
//Empty result set
}
//You dont have to test for null result set