目次
创建项目

" >创建项目

设计页面

" >设计页面

配置下拉列表

" >配置下拉列表

配置表

" >配置表

更改Column组件

" >更改Column组件

为表配置虚拟表单

" >为表配置虚拟表单

添加事件和初始化代码

" >添加事件和初始化代码

ホームページ データベース mysql チュートリアル NetBeans下构建操作数据库行的Web应用程序(一)

NetBeans下构建操作数据库行的Web应用程序(一)

Jun 07, 2016 pm 03:41 PM
netbeans web アプリ 操作する データベース 構築する

本教程介绍了如何使用具备 Web 功能的 NetBeans IDE 构建一个可以创建、检索、更新和删除数据库行的 Web 应用程序。该应用程序提供一个主数据的下拉列表以及一个同步的详细信息表。该 应用程序的用户可以在详细信息表及其关联数据库中添加、更新和删除记录。

本教程介绍了如何使用具备Web功能的NetBeans IDE构建一个可以创建、检索、更新和删除数据库行的Web应用程序。该应用程序提供一个主数据的下拉列表以及一个同步的详细信息表。该 应用程序的用户可以在详细信息表及其关联数据库中添加、更新和删除记录。

本教程使用了其他基础教程中介绍的一些概念。如果您不具备 IDE 及其设计组件的基本知识,可以考虑首先阅读一些入门教程,比如Visual Web JSF应用程序开发入门使用Databound组件访问数据库

预计时间:45分钟

目录

-       创建项目

-       添加插入功能

-       修改页面以保存行集

-       添加删除功能

-       添加恢复功能

-       结束语

本教程将使用以下技术和资源

JavaServer Faces组件/
Java EE
平台

1.2/Java EE 5*
1.1/J2EE 1.4

Travel 数据库

必需

* 为了利用NetBeans IDEJava EE 5功能,可以使用完全与Java EE 5规范兼容的应用程序服务器,比如Sun Java Application Server 9/GlassFish

本教程专门适用于GlassFish v2应用程序服务器。如果您使用的是其他服务器,请参考发行说明常见问题解答了解已知问题和解决方法。有关支持的服务器和Java EE平台的详细信息,请参阅发行说明

创建项目

在本教程中,我们将创建一个单页的Web应用程序。您可以先从设计页面布局入手,该页面包含一个人名及其相应的行程,

设计页面

1.   创建一个名为<span>InsertUpdateDelete</span>的新Web应用程序,该程序使用Visual Web JavaServer Faces框架。该应用程序的Page1.jsp文件会在Visual Designer中打开。

2.   PaletteBasic区域拖动一个Drop Down List组件到页面的左上角。在Properties窗口中,将其<span>id</span>属性更改为<span>personDD</span>

3.  Basic Palette中拖动一个Message Group组件到页面中,并将其放置在下拉列表的右侧。

Message Group组件可用来显示验证错误和转换错误,并且可以显示由<span>info</span><span>error</span>方法写入到Java Server Faces上下文的消息。如果需要调试项目,这些消息将会非常有用。

4.   将一个Table组件放置在这两个组件的下方。

配置下拉列表

1.  打开Services窗口,展开Databases节点,连接到Travel数据库。

如果TRAVEL数据库的jdbc节点标记显示为连接中断 ,并且无法展开该节点,则表明IDE未连接到该数据库。要连接TRAVEL数据库,请右键单击TRAVEL数据库的jdbc节点,然后从弹出菜单中选择Connect 选项。如果出现Connect对话框,请输入<span>travel</span>作为口令,选中Remember Password,然后单击OK按钮。如果看不到TRAVEL数据库的jdbc节点,请参见NetBeans数据库连接常见问题解答了解如何为IDE提供可用的数据库。 注意:如果您使用的是Apache Tomcat,请将<span>derbyClient.jar</span>文件复制到<span><tomcat_install>/common/lib</tomcat_install></span>目录,然后再尝试连接数据库。

2.  展开TRAVEL数据库的jdbc节点,然后展开Tables节点。

注意:在本教程的其余部分中,我们将TRAVEL数据库的jdbc节点称为Travel节点。

3.  PERSON节点拖动到Visual Designer中的下拉列表上。

Navigator窗口的Page1部分中将显示personDataProvider 点,SessionBean1部分中将显示personRowSet节点。

4.  右键单击Drop Down List组件,并从弹出菜单中选择Auto-Submit on Change选项。

此设置使得每当您从列表中选择新值时,就会将该页面发送到服务器。

5.  右键单击该下拉列表,并从弹出菜单中选择Configure Virtual Forms选项。

在出现的对话框中,请注意<span>personDD</span>显示在窗口的左上角,这表明下拉列表已被选定。

6.  单击New按钮并在Name列中键入<span>person</span>。双击Participate列下面的字段,将其设置为<span>Yes</span>,然后对Submit列执行同样的操作,

通过使用虚拟表单,应用程序可避免对Table中的数据进行不必要的验证。

7.   单击OK按钮。

8.  单击Visual Designer工具栏中的Show Virtual Forms按钮 通过查看虚拟表单,您可以查看Visual Designer中的组件与您已经配置的任何虚拟表单之间的关系。

配置表

1.    Services窗口中的Travel > Tables > TRIP节点拖动到Visual Designer中的Table组件上。

如果提示选择接收该节点的目标组件,则选择table1并单击OK按钮。

2.    右键单击Table并从弹出菜单中选择Table Layout选项。

Table Layout对话框会显示您刚创建的tripDataProvider中可用的字段,并允许您控制要在表中显示哪些字段。

3.    使用按钮从右侧的Selected列表中删除TRIP.TRIPIDTRIP.PERSONIDTRIP.LASTUPDATED

4.     单击Options选项卡,将Title 改为<span><font face="宋体">Trips</font></span> <span>Summary</span>,然后单击OK按钮。

5.    现在,可视设计器中的Table组件应如下图所示。注意:如果未按下图顺序显示各列,可通过重新打开Table Layout对话框,单击Columns选项卡,并使用UpDown按钮来重新排列它们。

6.             Navigator窗口中,右键单击SessionBean1下面的tripRowSet,并从弹出菜单中选择Edit SQL Statement选项。

这将打开SQL Query Editor

7.  在窗口中心附近的网格区域,右键单击PERSONID行并选择Add Query Criteria选项,8.  Add Query Criteria对话框中,将Comparison下拉菜单设置为<span>=Equals</span>并选择Parameter单选按钮,然后单击OK按钮。


字符“=?”将出现在PERSONIDCriteria字段中,并且条件“WHERE TRAVEL.TRIP.PERSONID=?”会出现在编辑器底部的SQL窗格中的SQL语句的结尾。

9.   关闭tripRowSetSQL编辑器。

更改Column组件

现在,将列内容更改为可编辑的字段,以准备实现将新行程插入到数据库中的功能。执行此操作时,可通过在Table组件中嵌套其他组件以利用其复合特性。

1.              右键单击Table组件并选择Table Layout选项。

将打开Table Layout对话框。

2.              Columns选项卡中,从右侧的Selected列表中选择TRIP.DEPDATE。在对话框底部的Column Details区域,将Component TypeStatic Text更改为Text Field,如下图所示,然后单击Apply按钮。

3.               TRIP.DEPCITYTRIP.DESTCITY执行同样的操作。

4.               Selected列表中选择TRIP.TRIPTYPEID,并将Component TypeStatic Text更改为Drop Down List

5.               单击OK按钮。

6.              Travel > Tables > TRIPTYPE节点拖放到Table组件中的Drop Down List上。如果Choose Target对话框打开,选择dropDown1选项并单击OK按钮。

此操作将创建 <span>triptypeDataProvider</span>

为表配置虚拟表单

接下来,为表中的输入组件创建一个虚拟表单。通过使用虚拟表单,可以确保在更改personDD下拉列表后提交此页时,不会对输入组件进行验证和转换。用户无论何时从下拉列表中选择新人员,都会在表中显示正确的信息。

1.               Visual Designer中,按住Ctrl键的同时在表中单击,以选择包含文本字段的三个列中的三个Text Field组件以及TRIPTYPEID列中的Drop Down List组件。

2.               右键单击其中一个选定的组件,并从弹出菜单中选择Configure Virtual Forms

3.               Configure Virtual Forms对话框中,请确保窗口的左上角列出了三个Text FieldDrop Down List。如果未按下图所示的方式列出这些内容,请 关闭对话框,重新选择它们,然后再试一次。如果已正确列出这些内容,则单击New按钮。

4.              将新虚拟表单的名称更改为<span>save</span>,将Participate设置更改为Yes

添加事件和初始化代码

现在,将personDD personDD Drop Down ListTable组件关联起来,以实现以下行为:当用户从列表中选择某人时,表中则会显示出此人的行程。

1.               双击personDD Drop Down List以创建一个值更改事件方法,并在该方法上打开Java Editor

2.              personDD_processValueChange方法中,添加Code Sample 1中的粗体文本,然后按下Alt-Shift-F组合键以重新设置代码格式。

代码示例 1:下拉列表事件处理程序

<span><font face="宋体"><span>   </span>public void personDD_processValueChange(ValueChangeEvent event) {<strong><p></p></strong></font></span>
ログイン後にコピー
<span><font face="宋体"><span>       </span>Object selectedPersonId = personDD.getSelected();<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>       </span>try {<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>  </span><span>         </span>personDataProvider.setCursorRow(<br>
<span>                   </span>personDataProvider.findFirst("PERSON.PERSONID",<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>                                  </span>selectedPersonId));<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>getSessionBean1().getTripRowSet().setObject(1, selectedPersonId);<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>tripDataProvider.refresh();<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>form1.discardSubmittedValues("save");<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>       </span>} catch (Exception e) {<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>error("Cannot switch to person " + selectedPersonId);<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>log("Cannot switch to person " + selectedPersonId, e);<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>       </span>}<p></p></font></span>
ログイン後にコピー
ログイン後にコピー
<span><font face="宋体"><span>   </span>}<p></p></font></span>
ログイン後にコピー
ログイン後にコピー

 

3.              位于<span>try</span>子句结尾处的<span>form1.discardSubmittedValues("save")</span>语句可确保每当用户从下拉列表中选择新的人员时,将使用与所选人员相关的新信息替换表中所显示的当前行程信息。注意表格中显示旅程信息的所有用户界面元素都参与名为 <span>save</span> 的虚拟表单。

4.              另外,该事件处理器不会抛出异常。而是把它们记录到<span>server.log</span>文件。该事件处理器也会调用<span>error</span>方法,当出现错误时,该方法会在Message Group组件中显示一条错误消息。

5.              Java源代码中滚动至<span>prerender</span>方法,或者(如果您愿意)使用Ctrl-F查找<span>prerender</span>。将下面以粗体显示的代码添加到该方法中。

代码示例 2Prerender 方法

<span><font face="宋体">public void prerender() {<strong><p></p></strong></font></span>
ログイン後にコピー
<span><font face="宋体"><span>       </span>if ( personDD.getSelected() == null ) {<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>Object firstPersonId = null;<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>try {<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>               </span>personDataProvider.cursorFirst();<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>        </span><span>       </span>firstPersonId = personDataProvider.getValue("PERSON.PERSONID");<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>               </span>personDD.setSelected(firstPersonId);<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>               </span>getSessionBean1().getTripRowSet().setObject(<br>
<span>                       </span>1, firstPersonId);<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>               </span>tripDataProvider.refresh();<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>} catch (Exception e) {<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>               </span>error("Cannot switch to person " +<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>                       </span>firstPersonId);<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>               </span>log("Cannot switch to person " +<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>                       </span>firstPersonId, e);<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>           </span>}<p></p></font></span>
ログイン後にコピー
<span><font face="宋体"><span>       </span>}<p></p></font></span>
ログイン後にコピー
ログイン後にコピー
<span><font face="宋体"><span>   </span>}<p></p></font></span>
ログイン後にコピー
ログイン後にコピー

6.               Java Editor中单击右键,然后选择Format以使代码正确对齐。

 
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ShazamアプリがiPhoneで動作しない:修正 ShazamアプリがiPhoneで動作しない:修正 Jun 08, 2024 pm 12:36 PM

iPhone の Shazam アプリに問題がありますか? Shazam は、曲を聞いて曲を見つけるのに役立ちます。ただし、Shazam が正常に動作しない場合、または曲が認識されない場合は、手動でトラブルシューティングを行う必要があります。 Shazam アプリの修復にはそれほど時間はかかりません。したがって、これ以上時間を無駄にすることなく、以下の手順に従って Shazam アプリの問題を解決してください。解決策 1 – 太字テキスト機能を無効にする iPhone の太字テキストが、Shazam が正しく動作しない原因である可能性があります。ステップ 1 – これは iPhone の設定からのみ実行できます。それで、開けてください。ステップ 2 – 次に、そこにある「ディスプレイと明るさ」設定を開きます。ステップ 3 – 「太字テキスト」が有効になっている場合

Hibernate はポリモーフィック マッピングをどのように実装しますか? Hibernate はポリモーフィック マッピングをどのように実装しますか? Apr 17, 2024 pm 12:09 PM

Hibernate ポリモーフィック マッピングは、継承されたクラスをデータベースにマップでき、次のマッピング タイプを提供します。 join-subclass: 親クラスのすべての列を含む、サブクラス用の別個のテーブルを作成します。 table-per-class: サブクラス固有の列のみを含む、サブクラス用の別個のテーブルを作成します。 Union-subclass: join-subclass と似ていますが、親クラス テーブルがすべてのサブクラス列を結合します。

iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます Jul 18, 2024 am 05:48 AM

Apple の最新リリースの iOS18、iPadOS18、および macOS Sequoia システムでは、さまざまな理由で紛失または破損した写真やビデオをユーザーが簡単に回復できるように設計された重要な機能が写真アプリケーションに追加されました。この新機能では、写真アプリのツール セクションに「Recovered」というアルバムが導入され、ユーザーがデバイス上に写真ライブラリに含まれていない写真やビデオがある場合に自動的に表示されます。 「Recovered」アルバムの登場により、データベースの破損、カメラ アプリケーションが写真ライブラリに正しく保存されない、または写真ライブラリを管理するサードパーティ アプリケーションによって失われた写真やビデオに対する解決策が提供されます。ユーザーはいくつかの簡単な手順を実行するだけで済みます

PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル Jun 04, 2024 pm 01:42 PM

MySQLi を使用して PHP でデータベース接続を確立する方法: MySQLi 拡張機能を含める (require_once) 接続関数を作成する (functionconnect_to_db) 接続関数を呼び出す ($conn=connect_to_db()) クエリを実行する ($result=$conn->query()) 閉じる接続 ( $conn->close())

PHP でデータベース接続エラーを処理する方法 PHP でデータベース接続エラーを処理する方法 Jun 05, 2024 pm 02:16 PM

PHP でデータベース接続エラーを処理するには、次の手順を使用できます。 mysqli_connect_errno() を使用してエラー コードを取得します。 mysqli_connect_error() を使用してエラー メッセージを取得します。これらのエラー メッセージをキャプチャしてログに記録することで、データベース接続の問題を簡単に特定して解決でき、アプリケーションをスムーズに実行できるようになります。

Astar ステーキングの原則、収入の解体、エアドロップ プロジェクトと戦略、および運営のナニー レベルの戦略 Astar ステーキングの原則、収入の解体、エアドロップ プロジェクトと戦略、および運営のナニー レベルの戦略 Jun 25, 2024 pm 07:09 PM

目次 Astar Dapp ステーキングの原則 ステーキング収益 潜在的なエアドロップ プロジェクトの解体: AlgemNeurolancheHealthreeAstar Degens DAOVeryLongSwap ステーキング戦略と運用 「AstarDapp ステーキング」は今年初めに V3 バージョンにアップグレードされ、ステーキング収益に多くの調整が加えられましたルール。現在、最初のステーキング サイクルが終了し、2 番目のステーキング サイクルの「投票」サブサイクルが始まったばかりです。 「追加報酬」特典を獲得するには、この重要な段階を把握する必要があります (6 月 26 日まで続く予定で、残りは 5 日未満です)。 Astarステーキング収入を詳しく説明します。

Golangを使用してリモートデータベースに接続するにはどうすればよいですか? Golangを使用してリモートデータベースに接続するにはどうすればよいですか? Jun 01, 2024 pm 08:31 PM

Go 標準ライブラリのデータベース/SQL パッケージを通じて、MySQL、PostgreSQL、SQLite などのリモート データベースに接続できます。データベース接続情報を含む接続文字列を作成します。 sql.Open() 関数を使用してデータベース接続を開きます。 SQL クエリや挿入操作などのデータベース操作を実行します。 defer を使用してデータベース接続を閉じ、リソースを解放します。

Golangでデータベースコールバック関数を使用するにはどうすればよいですか? Golangでデータベースコールバック関数を使用するにはどうすればよいですか? Jun 03, 2024 pm 02:20 PM

Golang でデータベース コールバック関数を使用すると、次のことを実現できます。 指定されたデータベース操作が完了した後にカスタム コードを実行します。追加のコードを記述せずに、個別の関数を通じてカスタム動作を追加します。コールバック関数は、挿入、更新、削除、クエリ操作に使用できます。コールバック関数を使用するには、sql.Exec、sql.QueryRow、または sql.Query 関数を使用する必要があります。

See all articles