찾다
데이터 베이스MySQL 튜토리얼javafx学习之数据库操作

javafx学习之数据库操作

Jun 07, 2016 pm 03:36 PM
javajavafx공부하다우리를작동하다데이터 베이스

上次我们学习的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"//标题
                message    : "SQL: {e.getMessage()}"//消息体
                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();
}
 

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL : 초보자가 마스터하는 필수 기술MySQL : 초보자가 마스터하는 필수 기술Apr 18, 2025 am 12:24 AM

MySQL은 초보자가 데이터베이스 기술을 배우는 데 적합합니다. 1. MySQL 서버 및 클라이언트 도구를 설치하십시오. 2. SELECT와 같은 기본 SQL 쿼리를 이해하십시오. 3. 마스터 데이터 작업 : 데이터를 만들고, 삽입, 업데이트 및 삭제합니다. 4. 고급 기술 배우기 : 하위 쿼리 및 창 함수. 5. 디버깅 및 최적화 : 구문 확인, 인덱스 사용, 선택*을 피하고 제한을 사용하십시오.

MySQL : 구조화 된 데이터 및 관계형 데이터베이스MySQL : 구조화 된 데이터 및 관계형 데이터베이스Apr 18, 2025 am 12:22 AM

MySQL은 테이블 구조 및 SQL 쿼리를 통해 구조화 된 데이터를 효율적으로 관리하고 외래 키를 통해 테이블 ​​간 관계를 구현합니다. 1. 테이블을 만들 때 데이터 형식을 정의하고 입력하십시오. 2. 외래 키를 사용하여 테이블 간의 관계를 설정하십시오. 3. 인덱싱 및 쿼리 최적화를 통해 성능을 향상시킵니다. 4. 데이터 보안 및 성능 최적화를 보장하기 위해 데이터베이스를 정기적으로 백업 및 모니터링합니다.

MySQL : 주요 기능 및 기능이 설명되었습니다MySQL : 주요 기능 및 기능이 설명되었습니다Apr 18, 2025 am 12:17 AM

MySQL은 웹 개발에 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 주요 기능에는 다음이 포함됩니다. 1. 다른 시나리오에 적합한 InnoDB 및 MyISAM과 같은 여러 스토리지 엔진을 지원합니다. 2.로드 밸런싱 및 데이터 백업을 용이하게하기 위해 마스터 슬레이브 복제 기능을 제공합니다. 3. 쿼리 최적화 및 색인 사용을 통해 쿼리 효율성을 향상시킵니다.

SQL의 목적 : MySQL 데이터베이스와 상호 작용합니다SQL의 목적 : MySQL 데이터베이스와 상호 작용합니다Apr 18, 2025 am 12:12 AM

SQL은 MySQL 데이터베이스와 상호 작용하여 데이터 첨가, 삭제, 수정, 검사 및 데이터베이스 설계를 실현하는 데 사용됩니다. 1) SQL은 Select, Insert, Update, Delete 문을 통해 데이터 작업을 수행합니다. 2) 데이터베이스 설계 및 관리에 대한 생성, 변경, 삭제 문을 사용하십시오. 3) 복잡한 쿼리 및 데이터 분석은 SQL을 통해 구현되어 비즈니스 의사 결정 효율성을 향상시킵니다.

초보자를위한 MySQL : 데이터베이스 관리를 시작합니다초보자를위한 MySQL : 데이터베이스 관리를 시작합니다Apr 18, 2025 am 12:10 AM

MySQL의 기본 작업에는 데이터베이스, 테이블 작성 및 SQL을 사용하여 데이터에서 CRUD 작업을 수행하는 것이 포함됩니다. 1. 데이터베이스 생성 : createAbasemy_first_db; 2. 테이블 만들기 : CreateTableBooks (idintauto_incrementprimarykey, titlevarchar (100) notnull, authorvarchar (100) notnull, published_yearint); 3. 데이터 삽입 : InsertIntobooks (Title, Author, Published_year) VA

MySQL의 역할 : 웹 응용 프로그램의 데이터베이스MySQL의 역할 : 웹 응용 프로그램의 데이터베이스Apr 17, 2025 am 12:23 AM

웹 응용 프로그램에서 MySQL의 주요 역할은 데이터를 저장하고 관리하는 것입니다. 1. MySQL은 사용자 정보, 제품 카탈로그, 트랜잭션 레코드 및 기타 데이터를 효율적으로 처리합니다. 2. SQL 쿼리를 통해 개발자는 데이터베이스에서 정보를 추출하여 동적 컨텐츠를 생성 할 수 있습니다. 3.mysql은 클라이언트-서버 모델을 기반으로 작동하여 허용 가능한 쿼리 속도를 보장합니다.

MySQL : 첫 번째 데이터베이스 구축MySQL : 첫 번째 데이터베이스 구축Apr 17, 2025 am 12:22 AM

MySQL 데이터베이스를 구축하는 단계에는 다음이 포함됩니다. 1. 데이터베이스 및 테이블 작성, 2. 데이터 삽입 및 3. 쿼리를 수행하십시오. 먼저 CreateAbase 및 CreateTable 문을 사용하여 데이터베이스 및 테이블을 작성한 다음 InsertInto 문을 사용하여 데이터를 삽입 한 다음 최종적으로 SELECT 문을 사용하여 데이터를 쿼리하십시오.

MySQL : 데이터 저장에 대한 초보자 친화적 인 접근 방식MySQL : 데이터 저장에 대한 초보자 친화적 인 접근 방식Apr 17, 2025 am 12:21 AM

MySQL은 사용하기 쉽고 강력하기 때문에 초보자에게 적합합니다. 1.MySQL은 관계형 데이터베이스이며 CRUD 작업에 SQL을 사용합니다. 2. 설치가 간단하고 루트 사용자 비밀번호를 구성해야합니다. 3. 삽입, 업데이트, 삭제 및 선택하여 데이터 작업을 수행하십시오. 4. Orderby, Where and Join은 복잡한 쿼리에 사용될 수 있습니다. 5. 디버깅은 구문을 확인하고 쿼리를 분석하기 위해 설명을 사용해야합니다. 6. 최적화 제안에는 인덱스 사용, 올바른 데이터 유형 선택 및 우수한 프로그래밍 습관이 포함됩니다.

See all articles

핫 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 Hentai를 무료로 생성하십시오.

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기