java直接调用并执行sql脚本 - Go语言中文社区

java直接调用并执行sql脚本


直接上代码

package com.qfx.test;

import java.io.File;
import java.io.FileReader;
import java.io.Reader;
import java.nio.charset.Charset;
import java.sql.Connection;
import java.sql.DriverManager;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.jdbc.ScriptRunner;

public class ScriptRunnerExecSql {
    private static String dbHost="127.0.0.1";               // 数据库地址
    private static String dbName="test";                      // 数据库名称
    private static String userName = "test";                // 登录名称
    private static String userPassword = "test111";         // 登录密码
    private static String dbPort="3306";                      // 数据库端口号

    public static void main(String[] args) {
        try {
            Connection conn =getMySqlConnection();
            ScriptRunner runner = new ScriptRunner(conn);
            Resources.setCharset(Charset.forName("UTF-8")); //设置字符集,不然中文乱码插入错误
            runner.setLogWriter(null);//设置是否输出日志
            // 绝对路径读取
//          Reader read = new FileReader(new File("f:\test.sql"));
            // 从class目录下直接读取
            Reader read = Resources.getResourceAsReader("test.sql");
            runner.runScript(read);
            runner.closeConnection();
            conn.close();
            System.out.println("sql脚本执行完毕");
        } catch (Exception e) {
            System.out.println("sql脚本执行发生异常");
            e.printStackTrace();
        }
    }

    /**
     * @功能描述:   获取数据库连接
     *
     * @return
     * @throws Exception 
     */
    public static Connection getMySqlConnection() throws Exception {
        Class.forName("com.mysql.jdbc.Driver");
        String url="jdbc:mysql://"+dbHost+":"+dbPort+"/"+dbName+"?useUnicode=true&characterEncoding=utf-8&port="+dbPort+"&autoReconnect=true";
        return DriverManager.getConnection(url,userName,userPassword);
    }
}

目录结构及jar包

java直接调用并执行sql脚本

转载于:https://blog.51cto.com/1197822/2327844

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/weixin_33947521/article/details/92618643
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-06-06 09:31:45
  • 阅读 ( 1222 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢