国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

javafx學習之數據庫操作

來源:懂視網 責編:小采 時間:2020-11-09 07:29:08
文檔

javafx學習之數據庫操作

javafx學習之數據庫操作:上次我們學習的javafx連接數據庫的簡單操作,這次我們來做一個稍為復雜的操作數據庫示例.IDE是:netbeans 6 beat 2,數據庫用javaDB(jdb6自帶有javaDB數據庫,netbeans 6也帶有,本例使用IDE自帶的javaDB),由于水平問題中文只注解了部份代碼,請見諒.(如
推薦度:
導讀javafx學習之數據庫操作:上次我們學習的javafx連接數據庫的簡單操作,這次我們來做一個稍為復雜的操作數據庫示例.IDE是:netbeans 6 beat 2,數據庫用javaDB(jdb6自帶有javaDB數據庫,netbeans 6也帶有,本例使用IDE自帶的javaDB),由于水平問題中文只注解了部份代碼,請見諒.(如

上次我們學習的javafx連接數據庫的簡單操作,這次我們來做一個稍為復雜的操作數據庫示例.IDE是:netbeans 6 beat 2,數據庫用javaDB(jdb6自帶有javaDB數據庫,netbeans 6也帶有,本例使用IDE自帶的javaDB),由于水平問題中文只注解了部份代碼,請見諒.(如出錯,請把

上次我們學習的javafx連接數據庫的簡單操作,這次我們來做一個稍為復雜的操作數據庫示例.IDE是:netbeans 6 beat 2,數據庫用javaDB(jdb6自帶有javaDB數據庫,netbeans 6也帶有,本例使用IDE自帶的javaDB),由于水平問題中文只注解了部份代碼,請見諒.(如出錯,請把中文注解刪除)

import javafx.ui.*;
import java.lang.Thread;
import java.lang.Exception;
import java.sql.*;
import org.apache.derby.jdbc.*;


// Connect to database

public class Database {
public attribute driverName: String;
public attribute jdbcUrl : String;
public attribute user : String;
public attribute password : String;

public attribute driver : Driver;
public attribute conn : Connection;

public operation connect();
public operation shutdown();

public operation tableExists(table: String);
}// Database

attribute Database.conn = null;

//-------------------------連接數據庫-----------------------------------
operation Database.connect() {
// Load driver class using context class loader
// 加載驅動
var thread = Thread.currentThread();
var classLoader = thread.getContextClassLoader();
var driverClass = classLoader.loadClass(this.driverName);


// Instantiate and register JDBC driver
//實例并注冊驅動
this.driver = (Driver) driverClass.instantiate(); // JavaFX Class
DriverManager.registerDriver(driver);


// Connect to database
//連接數據庫
this.conn = DriverManager.getConnection(this.jdbcUrl, this.user, this.password);
}// Database.connect

//--------------------關閉資源---------------------------
operation Database.shutdown() {
var stmt: Statement = null;

if(null <> this.conn) {
try {
stmt = this.conn.createStatement();
stmt.close();
} catch(e:SQLException) {
e.printStackTrace();
} finally {
if(null <> stmt) {stmt.close();}
this.conn.close();
}
}// if(null <> stmt)
}// operation.Database.shutdown


operation Database.tableExists(table: String)
{
// Check if table exists
//檢查表是否存在,注意這里并沒有主動去刪除
var tableExists = false;
var dbmd = this.conn.getMetaData();
var rs = dbmd.getTables(null, null, '%', ['TABLE']);

while(rs.next()) {
if(table == rs.getString(3)) {
tableExists = true;
break;
}
}// while(rs.next())


return tableExists;
}// tableExists

// Single userName in the Todo list

class userName {
attribute id : Number;
attribute userName: String;
}// userName

// Todo list

class TODO {
attribute userNames : userName*;
attribute selecteduserName: Number;
attribute newuserName : String;

attribute conn : Connection;
attribute usedb : Boolean;
}// TODO

TODO.conn = null;
TODO.usedb = true;

//---------------------------數據插入---------------------------
trigger on insert userName into TODO.userNames {
// TODO: Remove userName from ListBox if an error occurs

if(this.usedb) {
try {
var stmt: Statement = this.conn.createStatement();

this.conn.setAutoCommit(false);

// Insert new userName in database
//往數據庫插入一條記錄
var rows = stmt.executeUpdate("INSERT INTO Uuser (userName) VALUES('{userName.userName}')");
println("INSERT rows: {rows} for {userName.userName}");


// Get userName of the userName from database
//從數據庫得到userName
var rs = stmt.executeQuery('SELECT userName FROM Uuser');
if(rs.next()) {
userName.userName = rs.getString(1);
this.conn.commit();
}// if(rs.next())
} catch(e:SQLException){
//以對話框的形式彈出異常
MessageDialog {
messageType: ERROR//消息內型
title : "TODO - Add userName"http://標題
message : "SQL: {e.getMessage()}"http://消息體
visible : true//可見
}// MessageDialog
} finally {
this.conn.setAutoCommit(true);//自動提交
}
}// if(this.usedb)
}// trigger on insert userName

//---------------------------數據刪除------------------------------------
trigger on delete userName from TODO.userNames {
// TODO: Insert userName again in ListBox if an error occurs

if(this.usedb) {
try {
var stmt: Statement = this.conn.createStatement();
//從數據庫刪除一條記錄
var rows = stmt.executeUpdate("DELETE FROM Uuser WHERE userName = '{userName.userName}'");
println("DELETE rows: {rows} for {userName.userName}");
} catch(e:SQLException) {
MessageDialog {
messageType: ERROR
title : "TODO - Delete userName"
message : "SQL: {e.getMessage()}"
visible : true
}// MessageDialog
}
}// if(this.usedb)
}// trigger on delete

// Database vars

var db : Database = null;
var stmt: Statement = null;
var rs : ResultSet = null;

var rows: Number;

db = Database{driverName: 'org.apache.derby.jdbc.ClientDriver'//數據庫驅動類
jdbcUrl : 'jdbc:derby://localhost:1527/sample'//數據庫連接url
user : 'app'//用戶名
password : 'app'};//密碼

var model = TODO {
conn: bind lazy db.conn
};


//-------------------------------創建表----------------------------
try {
// Connect to database

db.connect();
stmt = db.conn.createStatement();


// Create table
//創建表,并插入兩條記錄
if(not db.tableExists('Uuser'))
{
rows = stmt.executeUpdate("CREATE TABLE Uuser(id INT , userName VARCHAR(50))");
println("CREATE TABLE rows: {rows}");

rows = stmt.executeUpdate("INSERT INTO Uuser VALUES(1, 'do')");
println("INSERT rows: {rows}");

rows = stmt.executeUpdate("INSERT INTO Uuser VALUES(2, 'did')");
println("INSERT rows: {rows}");


}// if(not db.tableExists('Uuser'))


// Get userNames from database and add userNames to model.userNames (ListBox)

model.usedb = false;
//從數據庫讀取記錄,并插入到model.userNames(其實就是顯示在listBox)
var rs = stmt.executeQuery("SELECT * FROM Uuser ORDER BY id ASC");

while(rs.next()) {
println("id: {rs.getInt('id')} userName: {rs.getString('userName')}");
insert userName{id: rs.getInt('id') userName: rs.getString('userName')} into model.userNames;
}

model.usedb = true;


//--------------------------面板-----------------------------
Frame {
title : "TODO list with JFXTrigger Example"
onClose: function() {
return db.shutdown();//面板關閉,關閉數據庫相關資源
}

content: BorderPanel {
center: ListBox {
selection: bind model.selecteduserName
cells : bind foreach (userName in model.userNames)
ListCell {
text: userName.userName
}
}// ListBox

bottom: FlowPanel {
content: [
TextField {
columns: 30
value : bind model.newuserName
}, // TextField

//增加按鈕,點擊增加一條記錄
Button {
text : 'Add'
enabled: bind model.newuserName.length() > 0
action : operation() {
insert userName{userName: model.newuserName} into model.userNames;
model.newuserName = '';
}
}, // Button
//刪除按鈕,點擊刪除一條記錄
Button {
text : 'Delete'
enabled: bind sizeof model.userNames > 0
action : operation() {
delete model.userNames[model.selecteduserName];
}// Button
}
]// content
}// FlowPanel
}// BorderPanel

visible: true
}// Frame

} catch(e:SQLException) {
e.printStackTrace();
}

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

javafx學習之數據庫操作

javafx學習之數據庫操作:上次我們學習的javafx連接數據庫的簡單操作,這次我們來做一個稍為復雜的操作數據庫示例.IDE是:netbeans 6 beat 2,數據庫用javaDB(jdb6自帶有javaDB數據庫,netbeans 6也帶有,本例使用IDE自帶的javaDB),由于水平問題中文只注解了部份代碼,請見諒.(如
推薦度:
標簽: 操作 學習 數據庫
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产成人精品一区二区不卡 | 日产精品久久久一区二区 | 国产中文字幕视频 | 中文在线第一页 | 亚洲综合欧美日本另类激情 | 毛片免费观看成人 | 国产女上位 | 成人区精品一区二区毛片不卡 | 极品国产高颜值露脸在线 | 日本不卡视频一区二区三区 | 欧美日韩亚洲国产一区二区三区 | 国产精品观看 | 亚洲第一页在线视频 | 日本久久久久久久 | 91精品国产91久久久久久最新 | xxxxx欧美| 国产一区二区三区在线 | 国产日产精品_国产精品毛片 | 男女全黄一级带免费 | 日韩黄色网页 | 成人无码一区二区片 | 国内精品久久久久久中文字幕 | 欧美色视频在线观看 | 精品久久久久久久中文字幕 | 欧美 国产 日韩 第一页 | 亚洲视频网站在线观看 | 国产成人久久精品亚洲小说 | 国产成人一区二区小说 | 日本精品久久久一区二区三区 | 免费观看a黄一级视频 | 国产精品美女一区二区三区 | 亚洲欧美网站 | 国产欧美高清 | 欧美综合国产精品日韩一 | 国产亚洲精品一品区99热 | 日本成人一区二区 | 亚洲综合一区二区精品久久 | 伊人久久精品一区二区三区 | 亚洲欧洲在线观看 | 国产自在自线午夜精品视频 | 99精品国产免费久久国语 |