NetBeans下构建操作数据库行的Web应用程序(一)
本教程介绍了如何使用具备 Web 功能的 NetBeans IDE 构建一个可以创建、检索、更新和删除数据库行的 Web 应用程序。该应用程序提供一个主数据的下拉列表以及一个同步的详细信息表。该 应用程序的用户可以在详细信息表及其关联数据库中添加、更新和删除记录。
本教程介绍了如何使用具备Web功能的NetBeans IDE构建一个可以创建、检索、更新和删除数据库行的Web应用程序。该应用程序提供一个主数据的下拉列表以及一个同步的详细信息表。该 应用程序的用户可以在详细信息表及其关联数据库中添加、更新和删除记录。
本教程使用了其他基础教程中介绍的一些概念。如果您不具备 IDE 及其设计组件的基本知识,可以考虑首先阅读一些入门教程,比如Visual Web JSF应用程序开发入门和使用Databound组件访问数据库。
预计时间:45分钟
目录
- 创建项目
- 添加插入功能
- 修改页面以保存行集
- 添加删除功能
- 添加恢复功能
- 结束语
本教程将使用以下技术和资源
JavaServer Faces组件/ |
|
Travel 数据库 |
|
* 为了利用NetBeans IDE的Java 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. 从Palette的Basic区域拖动一个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节点标记显示为连接中断 <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按钮
配置表
1. 将Services窗口中的Travel > Tables > TRIP节点拖动到Visual Designer中的Table组件上。
如果提示选择接收该节点的目标组件,则选择table1并单击OK按钮。
2. 右键单击Table并从弹出菜单中选择Table Layout选项。
Table Layout对话框会显示您刚创建的tripDataProvider中可用的字段,并允许您控制要在表中显示哪些字段。
3. 使用按钮从右侧的Selected列表中删除TRIP.TRIPID、TRIP.PERSONID和TRIP.LASTUPDATED,
4. 单击Options选项卡,将Title 改为<span><font face="宋体">Trips</font></span>
<span>Summary</span>
,然后单击OK按钮。
5. 现在,可视设计器中的Table组件应如下图所示。注意:如果未按下图顺序显示各列,可通过重新打开Table Layout对话框,单击Columns选项卡,并使用Up和Down按钮来重新排列它们。
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按钮。
字符“=?”将出现在PERSONID的Criteria字段中,并且条件“WHERE TRAVEL.TRIP.PERSONID=?”会出现在编辑器底部的SQL窗格中的SQL语句的结尾。
9. 关闭tripRowSet的SQL编辑器。
更改Column组件
现在,将列内容更改为可编辑的字段,以准备实现将新行程插入到数据库中的功能。执行此操作时,可通过在Table组件中嵌套其他组件以利用其复合特性。
1. 右键单击Table组件并选择Table Layout选项。
将打开Table Layout对话框。
2. 在Columns选项卡中,从右侧的Selected列表中选择TRIP.DEPDATE。在对话框底部的Column Details区域,将Component Type从Static Text更改为Text Field,如下图所示,然后单击Apply按钮。
3. 对TRIP.DEPCITY和TRIP.DESTCITY执行同样的操作。
4. 在Selected列表中选择TRIP.TRIPTYPEID,并将Component Type从Static 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 Field和Drop Down List。如果未按下图所示的方式列出这些内容,请 关闭对话框,重新选择它们,然后再试一次。如果已正确列出这些内容,则单击New按钮。
4. 将新虚拟表单的名称更改为<span>save</span>
,将Participate设置更改为Yes,
添加事件和初始化代码
现在,将personDD personDD Drop Down List和Table组件关联起来,以实现以下行为:当用户从列表中选择某人时,表中则会显示出此人的行程。
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>
。将下面以粗体显示的代码添加到该方法中。
代码示例 2:Prerender 方法 |
<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以使代码正确对齐。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











iPhone의 Shazam 앱에 문제가 있나요? Shazam은 노래를 듣고 노래를 찾는 데 도움을 줍니다. 하지만 Shazam이 제대로 작동하지 않거나 노래를 인식하지 못하는 경우 수동으로 문제를 해결해야 합니다. Shazam 앱을 복구하는 데 시간이 오래 걸리지 않습니다. 따라서 더 이상 시간을 낭비하지 않고 아래 단계에 따라 Shazam 앱 문제를 해결하세요. 수정 1 – 굵은 텍스트 기능 비활성화 iPhone의 굵은 텍스트로 인해 Shazam이 제대로 작동하지 않을 수 있습니다. 1단계 – iPhone 설정에서만 이 작업을 수행할 수 있습니다. 그러니 열어보세요. 2단계 – 다음으로 "디스플레이 및 밝기" 설정을 엽니다. 3단계 - "굵은 텍스트"가 활성화된 경우

Hibernate 다형성 매핑은 상속된 클래스를 데이터베이스에 매핑할 수 있으며 다음 매핑 유형을 제공합니다. Join-subclass: 상위 클래스의 모든 열을 포함하여 하위 클래스에 대한 별도의 테이블을 생성합니다. 클래스별 테이블: 하위 클래스별 열만 포함하는 하위 클래스에 대한 별도의 테이블을 만듭니다. Union-subclass: Joined-subclass와 유사하지만 상위 클래스 테이블이 모든 하위 클래스 열을 통합합니다.

Apple의 최신 iOS18, iPadOS18 및 macOS Sequoia 시스템 릴리스에는 사진 애플리케이션에 중요한 기능이 추가되었습니다. 이 기능은 사용자가 다양한 이유로 손실되거나 손상된 사진과 비디오를 쉽게 복구할 수 있도록 설계되었습니다. 새로운 기능에는 사진 앱의 도구 섹션에 '복구됨'이라는 앨범이 도입되었습니다. 이 앨범은 사용자가 기기에 사진 라이브러리에 포함되지 않은 사진이나 비디오를 가지고 있을 때 자동으로 나타납니다. "복구된" 앨범의 출현은 데이터베이스 손상으로 인해 손실된 사진과 비디오, 사진 라이브러리에 올바르게 저장되지 않은 카메라 응용 프로그램 또는 사진 라이브러리를 관리하는 타사 응용 프로그램에 대한 솔루션을 제공합니다. 사용자는 몇 가지 간단한 단계만 거치면 됩니다.

MySQLi를 사용하여 PHP에서 데이터베이스 연결을 설정하는 방법: MySQLi 확장 포함(require_once) 연결 함수 생성(functionconnect_to_db) 연결 함수 호출($conn=connect_to_db()) 쿼리 실행($result=$conn->query()) 닫기 연결( $conn->close())

PHP에서 데이터베이스 연결 오류를 처리하려면 다음 단계를 사용할 수 있습니다. mysqli_connect_errno()를 사용하여 오류 코드를 얻습니다. 오류 메시지를 얻으려면 mysqli_connect_error()를 사용하십시오. 이러한 오류 메시지를 캡처하고 기록하면 데이터베이스 연결 문제를 쉽게 식별하고 해결할 수 있어 애플리케이션이 원활하게 실행될 수 있습니다.

목차 Astar Dapp 스테이킹 원리 스테이킹 수익 잠재적 에어드랍 프로젝트 해체: AlgemNeurolancheHealThreeAstar Degens DAOVeryLongSwap 스테이킹 전략 및 운영 "AstarDapp 스테이킹"이 올해 초 V3 버전으로 업그레이드되었으며 스테이킹 수익에 많은 조정이 이루어졌습니다. 규칙. 현재 첫 번째 스테이킹 주기는 종료되었으며 두 번째 스테이킹 주기의 "투표" 하위 주기가 막 시작되었습니다. '추가 보상' 혜택을 받으려면 이 중요한 단계(6월 26일까지 지속 예정, 5일 미만 남았음)를 파악해야 합니다. 아스타 스테이킹 수익을 자세하게 분석해보겠습니다.

Go 표준 라이브러리 데이터베이스/sql 패키지를 통해 MySQL, PostgreSQL 또는 SQLite와 같은 원격 데이터베이스에 연결할 수 있습니다. 데이터베이스 연결 정보가 포함된 연결 문자열을 생성합니다. sql.Open() 함수를 사용하여 데이터베이스 연결을 엽니다. SQL 쿼리 및 삽입 작업과 같은 데이터베이스 작업을 수행합니다. 리소스를 해제하기 위해 defer를 사용하여 데이터베이스 연결을 닫습니다.

Golang의 데이터베이스 콜백 기능을 사용하면 다음을 달성할 수 있습니다. 지정된 데이터베이스 작업이 완료된 후 사용자 정의 코드를 실행합니다. 추가 코드를 작성하지 않고도 별도의 함수를 통해 사용자 정의 동작을 추가할 수 있습니다. 삽입, 업데이트, 삭제, 쿼리 작업에 콜백 함수를 사용할 수 있습니다. 콜백 함수를 사용하려면 sql.Exec, sql.QueryRow, sql.Query 함수를 사용해야 합니다.
