为了账号安全,请及时绑定邮箱和手机立即绑定

java直接调用并执行sql脚本

标签:
Java


直接上代码

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的原创作品,如需转载,请注明出处,否则将追究法律责任


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消