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数据库的更多相关文章

  1. 关于利用PHP访问MySql数据库的逻辑操作以及增删改查实例操作

    PHP访问MySql数据库 <?php //造连接对象$db = new MySQLi("localhost","root","",& ...

  2. 利用Python访问Mysql数据库

    首先要明确一点,我们在Python中需要通过第三方库才能访问Mysql. 有这样几种方式:Mysql-python(即MySQLdb).pymysql.mysql-connector.Mysql-py ...

  3. 利用oneproxy部署mysql数据库的读写分离

    实验系统:CentOS 6.6_x86_64 实验前提:防火墙和selinux都关闭 实验说明:本实验共有4台主机,IP分配如拓扑 实验软件:mariadb-10.0.20 oneproxy-rhel ...

  4. 利用xtrabackup备份mysql数据库

    利用xtrabackup备份mysql数据库 一.安装1.直接下载二进制文件wget http://www.percona.com/downloads/XtraBackup/XtraBackup-2. ...

  5. java文件来演示如何访问MySQL数据库

    java文件来演示如何访问MySQL数据库. 注:在命令行或用一个SQL的前端软件创建Database. 先创建数据库: CREATE DATABASE SCUTCS; 接着,创建表: CREATE ...

  6. PHP访问MySql数据库介绍

    在网站后台,经常要与数据库打交道.本文介绍如何使用XAMPP来管理MySql数据库及如何用PHP来访问MySql数据库. 一.使用XAMPP来管理MySql数据库 首先使用XAMPP打开MySql的管 ...

  7. C#连接、访问MySQL数据库

    一.准备工具 visual stuido(本示例使用visual studio 2010) MySql.Data.dll mysql_installer_community_V5.6.21.1_set ...

  8. 在Eclipse中使用JDBC访问MySQL数据库的配置方法

    在Eclipse中使用JDBC访问MySQL数据库的配置方法 分类: DATABASE 数据结构与算法2009-10-10 16:37 5313人阅读 评论(10) 收藏 举报 jdbcmysql数据 ...

  9. C#访问MySQL数据库(winform+EF)

    原文:C#访问MySQL数据库(winform+EF) 以前都是C#连接SQLServer,现在MySQL也比较火了,而且是开源跨平台的,这里连接使用一下,主要是体会一下整个流程,这里使用的是winf ...

随机推荐

  1. 20155336 2016-2017-2 《Java程序设计》第三周学习总结

    20155336 2016-2017-2 <Java程序设计>第三周学习总结 教材学习内容总结 第四章 类与对象 定义: 对象(Object):存在的具体实体,具有明确的状态和行为. 类( ...

  2. 20155339 2017-2018-1《信息安全系统设计》第四周课堂测试、Makefile以及myod

    20155339 2017-2018-1<信息安全系统设计>第四周课堂测试.Makefile以及myod 测试1-vi 每个.c一个文件,每个.h一个文件,文件名中最好有自己的学号 用Vi ...

  3. [arc067F]Yakiniku Restaurants[矩阵差分]

    Description 传送门 Solution 假如我们确定了烧烤店区间[l,r],则票j必定会选择在B[i][j](l<=i<=r)最大的烧烤店使用. 反过来想,我们想要票j在第i个烧 ...

  4. 成都Uber优步司机奖励政策(4月11日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  5. 自己通过Cygwin编译的windowsx86下的更新至4.0.1

    采用方法:https://my.oschina.net/maxid/blog/186506 方法中在3.2.6未找到src/redis.h文件 未修改 方法中 /deps/hiredis/net.c ...

  6. java class file

    目录 什么是java类文件 幻数 主次版本号 常量池数和常量池 this_class super_class 接口数量和接口 字段数和字段 方法数和方法 以下内容主要还是参考<Inside JV ...

  7. Qt 利用XML文档,写一个程序集合 一

    接到领导需求安排,说公司未来的硬件设备会越来越多,与每个设备对应的设备检测和设置程序也会增多.导致软甲太多,不好掌控.所以希望做一个完整的软件,但是呢,每个子程序还得独立,应为每个用户购买的设备不是一 ...

  8. 001 -js对时间日期的排序

    001-JS对时间日期的排序 最近在做公司的项目时间,产品给了一个很简单的页面,让帮忙写一下.首先看一下产品的需求: 需要对该列表进行排序 思路:(1)可以在数据库写sql语句的时间直接一个DESC按 ...

  9. Spring单元测试集成H2数据库

    项目源代码在:Spring-H2测试 H2简介 H2数据库是一种由Java编写的,极小,速度极快,可嵌入式的数据库.非常适合用在单元测试等数据不需要保存的场景下面. 以下时其官网的介绍: {% blo ...

  10. Prometheus+Grafana监控部署实践

    参考文档: Prometheus github:https://github.com/prometheus grafana github:https://github.com/grafana/graf ...