搜尋
首頁类库下载java类库Java中如何使用嵌入MySQL

Java中如何使用嵌入MySQL

Nov 07, 2016 pm 05:30 PM
javamysql嵌入

这篇文件主要介绍在Java中嵌入式MySQL的使用,对于一些的应用项目,提供安装版的Mysql,Oracle是必须的工作。但是有时候如果是一个小的工具,可安装或者移植性比较强的小软件。再去安装数据库可能就比较麻烦了。

其实MySQL也有嵌入式的,不需要安装,在使用的过程中,会自动创建数据库以及通过代码的方式启动或者关闭。下面提供一些代码片段,具体的会提供下载地址。

这个是核心代码类,这个类实现了Mysql 的启动和停止以及数据库的启动状态。

package net.simple.mysql;

import java.io.File;
import java.util.HashMap;
import java.util.Map;
import java.util.Properties;
import java.util.Set;

import com.mysql.management.MysqldResource;

public final class EmbedMySqlServer {
    private MysqldResource mysqlInstance;
    //配置信息
    public final Properties props;
    //端口信息
    private String port;
    /**
     * 考虑到数据库的性能问题,允许将数据库放在其它磁盘
     */
    private String embedMySqlHome;

    public EmbedMySqlServer(final Properties props) {
        this.props = props;
    }

    public EmbedMySqlServer(final Properties props, String embedMySqlHome) {
        this.embedMySqlHome = embedMySqlHome;
        this.props = props;
    }

    public final String getEmbedMySqlHome() {
        return null == embedMySqlHome ? getPlatformBaseDir() : embedMySqlHome;
    }

    /**
    * 获得当前应用主目录
    * @return 当前应用启动程序所在目录.
    */
    public static String getPlatformBaseDir() {
        return System.getProperty("user.dir");
    }

    public static boolean isBlank(final String str) {
        int strLen;
        if (str == null || (strLen = str.length()) == 0) {
            return true;
        }
        for (int i = 0; i < strLen; i++) {
            if (Character.isWhitespace(str.charAt(i)) == false) {
                return false;
            }
        }
        return true;
    }

    public void startup() {
        final File baseDir = new File(getEmbedMySqlHome(), "mysql-em");
        mysqlInstance = new MysqldResource(baseDir);
        port = props.getProperty("port");
        if (isBlank(port))
            props.put("port", port = String.valueOf((int) (Math.random() * 40000)));
        final Set<Object> keys = props.keySet();
        final Map<String, String> options = new HashMap<String, String>(keys.size());
        for (final Object key : keys) {
            final String val = props.getProperty(key.toString());
            if ("".equals(val))
                options.put(key.toString(), null);
            else
                options.put(key.toString(), val.replace("{$contextPath}", getPlatformBaseDir()));
        }
        if (!mysqlInstance.isRunning())
            mysqlInstance.start("Em_MySQL", options, false, keys.contains("defaults-file"));
    }

    public String getPort() {
        return port;
    }

    /**
     * 判断mysql是否正在运行
     */
    public boolean isRunning() {
        return null == mysqlInstance ? false : mysqlInstance.isRunning();
    }

    public void shutdown() {
        if (mysqlInstance != null)
            mysqlInstance.shutdown();
    }

    public void cleanup() {
        if (mysqlInstance != null)
            mysqlInstance.cleanup();
    }
}

下面这个是启动Demo,

public static void main(String[] args) {
        try {
            Properties pro = new Properties();
            //根据机器配置,设置不同的参数
            pro.load(MysqlTest.class.getResourceAsStream("MySql_medium.properties"));
            new EmbedMySqlServer(pro).startup();
            //可以把数据库放到其他磁盘
            //new EmbedMySqlServer(pro,"f:\\").startup();
            Connection conn = getTestConnection();
            System.out.println(conn.isClosed());
            conn.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

MySql_general.properties一般机器的配置样例

MySql_medium.properties中等机器的配置样例

MySql_large.properties高配机的配置样例

具体的参数可以根据不同需求进行定义,比如端口可以自由定义。

需要引用的mysql两个jar,mysql-connector-mxj-gpl-6-0-11-db-files.jar,mysql-connector-mxj-gpl-6-0-11.jar

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。