利用JavaFX访问MySQL数据库
1. 创建数据库表
create table Course(
courseId char(5),
subjectId char(4) not null,
courseNumber integer,
title varchar(50) not null,
numOfCredits integer,
primary key (courseId)
);
create table Student(
ssn char(9),
firstName varchar(25),
mi char(1),
lastName varchar(25),
birthDate date,
street varchar(25),
phone char(11),
zipCode char(5),
deptId char(4),
primary key (ssn)
);
create table Enrollment(
ssn char(9),
courseId char(15),
dateRegistered date,
grade char(1),
primary key (ssn, courseId),
foreign key (ssn) references Student(ssn),
foreign key (courseId) references Course(courseId)
);
2. 创建JavaFX项目
package application;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import javafx.application.Application;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;
import javafx.scene.layout.HBox;
import javafx.scene.layout.VBox;
import javafx.stage.Stage; public class Main extends Application {
private Statement stmt;
private TextField tfSSN = new TextField();
private TextField tfCourseId = new TextField();
private Label lblStatus = new Label();// 存放查询结果 @Override
public void start(Stage primaryStage) {
try {
initializeDB(); Button bsShowGrade = new Button("Show Grade");
HBox hBox = new HBox(5);
hBox.getChildren().addAll(new Label("SSN"), tfSSN, new Label("Course Id"), tfCourseId, bsShowGrade); VBox vBox = new VBox(10);
vBox.getChildren().addAll(hBox, lblStatus); tfSSN.setPrefColumnCount(6);
tfCourseId.setPrefColumnCount(6);
bsShowGrade.setOnAction(new EventHandler<ActionEvent>() { @Override
public void handle(ActionEvent arg0) {
// TODO Auto-generated method stub
String ssn = tfSSN.getText();// 获取输入的SSN
String courseId = tfCourseId.getText();
try {
String queryString ="select firstName, mi, lastName, title, grade from Student, Enrollment, Course" +
" where Student.ssn = '"+ssn+"' and Enrollment.courseId "
+ "= '"+courseId+"' and Enrollment.courseId = Course.courseId"
+ " and Enrollment.ssn = Student.ssn";
String queryStrin = "select firstName, mi, lastName, grade from student, Enrollment where Student.ssn = '11' and Enrollment.ssn = Student.ssn";
ResultSet rSet = stmt.executeQuery(queryString);// 查询数据库,并返回查询结果 if (rSet.next()) {// 显示查询结果
String firstName = rSet.getString(1);
String mi = rSet.getString(2);
String lastName = rSet.getString(3);
String title = rSet.getString(4);
String grade = rSet.getString(5); lblStatus.setText(firstName + " " + mi + " " + lastName + " " + title + " " + grade);
} else {
lblStatus.setText("Not found");
}
} catch (SQLException ex) {
ex.printStackTrace();
}
}
}); Scene scene = new Scene(vBox, 420, 80);
primaryStage.setTitle("FindGrade");
primaryStage.setScene(scene);
primaryStage.show();
} catch (Exception e) {
e.printStackTrace();
}
} public static void main(String[] args) {
launch(args);
} private void initializeDB() {
try {
Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/dbname", "user", "password"); stmt = conn.createStatement();
} catch (Exception ex) {
ex.printStackTrace();
}
} }
运行结果:输入SSN和courseID,显示查询结果,如图。

另1:在eclipse中安装JavaFX
点击eclipse中的Help->Install New Software,在弹出的窗口中设置如下:
点击Work with框后的Add,在弹出的窗口中,设置如下:Name: ex(fx)lipse,Location:http://download.eclipse.org/efxclipse/updates-released/2.3.0/site/ ,点击OK。上述设置好后,会发现两个插件的复选框:e(fx)clipse – install 安装和e(fx)clipse – single components,选中这两个复选框,完成安装。
另2:开始程序一直报错:Not unique table/alias: 'student',网上查询是因为跟MySQL关键字重名,但并没有重名的字段,最后发现是SQL语句在换行时少了一个空格,因此要注意SQL语句在换行时的空格情况。
3. 利用PreparedStatement创建参数和的SQL语句
package application; import java.sql.*; import javafx.application.Application;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;
import javafx.scene.layout.HBox;
import javafx.scene.layout.VBox;
import javafx.stage.Stage; public class FindGradeUsingPreparedStatement extends Application{ private PreparedStatement preparedStatement;
private Statement stmt;
private TextField tfSSN = new TextField();
private TextField tfCourseId = new TextField();
private Label lblStatus = new Label();// 存放查询结果 @Override
public void start(Stage primaryStage) {
try {
Connection conn = initializeDB(); Button bsShowGrade = new Button("Show Grade");
HBox hBox = new HBox(5);
hBox.getChildren().addAll(new Label("SSN"), tfSSN, new Label("Course Id"), tfCourseId, bsShowGrade); VBox vBox = new VBox(10);
vBox.getChildren().addAll(hBox, lblStatus); tfSSN.setPrefColumnCount(6);
tfCourseId.setPrefColumnCount(6);
bsShowGrade.setOnAction(new EventHandler<ActionEvent>() { @Override
public void handle(ActionEvent arg0) {
// TODO Auto-generated method stub
String ssn = tfSSN.getText();
String courseId = tfCourseId.getText();
try {
String queryString ="select firstName, mi, lastName, title, grade from Student, Enrollment, Course" +
" where Student.ssn = ? and Enrollment.courseId "
+ "= ? and Enrollment.courseId = Course.courseId"
+ " and Enrollment.ssn = Student.ssn";//问号作为参数的占位符
preparedStatement = conn.prepareStatement(queryString); preparedStatement.setString(1, ssn);//设置占位符处的参数值
preparedStatement.setString(2, courseId);
ResultSet rSet = preparedStatement.executeQuery();//执行查询语句 if (rSet.next()) {// 显示查询结果
String firstName = rSet.getString(1);
String mi = rSet.getString(2);
String lastName = rSet.getString(3);
String title = rSet.getString(4);
String grade = rSet.getString(5); lblStatus.setText(firstName + " " + mi + " " + lastName + "'s grade on course " + title + " is " + grade);
} else {
lblStatus.setText("Not found");
}
} catch (SQLException ex) {
ex.printStackTrace();
}
}
}); Scene scene = new Scene(vBox, 420, 80);
primaryStage.setTitle("FindGrade");
primaryStage.setScene(scene);
primaryStage.show();
} catch (Exception e) {
e.printStackTrace();
}
} public static void main(String[] args) {
// TODO Auto-generated method stub
launch(args);
}
private Connection initializeDB() {
Connection conn = null;
try {
Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://localhost/dbname", "user", "password");
System.out.println("Database connected"); } catch (Exception ex) {
ex.printStackTrace();
}
return conn;
} }
参考资料:Java语言程序设计 进阶版
利用JavaFX访问MySQL数据库的更多相关文章
- 关于利用PHP访问MySql数据库的逻辑操作以及增删改查实例操作
PHP访问MySql数据库 <?php //造连接对象$db = new MySQLi("localhost","root","",& ...
- 利用Python访问Mysql数据库
首先要明确一点,我们在Python中需要通过第三方库才能访问Mysql. 有这样几种方式:Mysql-python(即MySQLdb).pymysql.mysql-connector.Mysql-py ...
- 利用oneproxy部署mysql数据库的读写分离
实验系统:CentOS 6.6_x86_64 实验前提:防火墙和selinux都关闭 实验说明:本实验共有4台主机,IP分配如拓扑 实验软件:mariadb-10.0.20 oneproxy-rhel ...
- 利用xtrabackup备份mysql数据库
利用xtrabackup备份mysql数据库 一.安装1.直接下载二进制文件wget http://www.percona.com/downloads/XtraBackup/XtraBackup-2. ...
- java文件来演示如何访问MySQL数据库
java文件来演示如何访问MySQL数据库. 注:在命令行或用一个SQL的前端软件创建Database. 先创建数据库: CREATE DATABASE SCUTCS; 接着,创建表: CREATE ...
- PHP访问MySql数据库介绍
在网站后台,经常要与数据库打交道.本文介绍如何使用XAMPP来管理MySql数据库及如何用PHP来访问MySql数据库. 一.使用XAMPP来管理MySql数据库 首先使用XAMPP打开MySql的管 ...
- C#连接、访问MySQL数据库
一.准备工具 visual stuido(本示例使用visual studio 2010) MySql.Data.dll mysql_installer_community_V5.6.21.1_set ...
- 在Eclipse中使用JDBC访问MySQL数据库的配置方法
在Eclipse中使用JDBC访问MySQL数据库的配置方法 分类: DATABASE 数据结构与算法2009-10-10 16:37 5313人阅读 评论(10) 收藏 举报 jdbcmysql数据 ...
- C#访问MySQL数据库(winform+EF)
原文:C#访问MySQL数据库(winform+EF) 以前都是C#连接SQLServer,现在MySQL也比较火了,而且是开源跨平台的,这里连接使用一下,主要是体会一下整个流程,这里使用的是winf ...
随机推荐
- Hibernate 3.0 HelloWorld
说明 基于Hibernate 3.0,Mysql5.0,java jdk 1.7,运行需要的lib 库,从http://files.cnblogs.com/HCCZX/Hibernate_Lib.ra ...
- LVS入门篇(五)之LVS+Keepalived实战
一.实验架构和环境说明 (1)本次基于VMware Workstation搭建一个四台Linux(CentOS 7.4)系统所构成的一个服务器集群,其中两台负载均衡服务器(一台为主机,另一台为备机), ...
- Elasticsearch6.2集群搭建
Elasticsearch6.2集群搭建 2018年04月02日 11:07:45 这个名字想了很久 阅读数:14154 版权声明:本博客为学习.笔记之用,以笔记形式记录学习的知识与感悟.学习过 ...
- linux下,将一个目录中的图片文件合成为gif图片
# {} 为文件所在目录位置 # {} 为gif图片位置 convert -delay -depth -layers optimize -quality -loop {} {}
- Spring Cloud(三):服务提供与调用 Eureka【Finchley 版】
Spring Cloud(三):服务提供与调用 Eureka[Finchley 版] 发表于 2018-04-15 | 更新于 2018-05-07 | 上一篇文章我们介绍了 Eureka 服务 ...
- Centos7.2部署saltstack
原文发表于cu:2016-06-23 参考文档: Saltstack安装文档:https://repo.saltstack.com/#rhel saltstack的安装与简单配置,应用. 一.环境 S ...
- XSS留言板实现
XSS 留言板实现-笔记 预备知识 XSS漏洞 XSS攻击全称跨站脚本攻击,是为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS,XSS ...
- sklearn中的交叉验证(Cross-Validation)
这个repo 用来记录一些python技巧.书籍.学习链接等,欢迎stargithub地址sklearn是利用python进行机器学习中一个非常全面和好用的第三方库,用过的都说好.今天主要记录一下sk ...
- 互评Alpha版本——可以低头,但没必要——取件帮
基于NABCD评论作品,及改进建议: 1.根据(不限于)NABCD评论作品的选题 (1)N(Need,需求) 随着电商平台的发展,越来越多的人选择网购,但是东师的一部分快递网点不在校内,需要走很长的一 ...
- Scrum立会报告+燃尽图 04
此作业要求参见https://edu.cnblogs.com/campus/nenu/2018fall/homework/2194 一.小组介绍 组长:王一可 组员:范靖旋,王硕,赵佳璐,范洪达,祁玉 ...