java执行mysql脚本_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脚本

©著作权归作者所有:来自51CTO博客作者pannijingling的原创作品,如需转载,请注明出处,否则将追究法律责任

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值