命令行编译带外部包依赖的java源文件 [以JDBC MySQL8为例]
环境: MySQL8 JDK11(SE)
首先下载MySQL8的JDBC驱动
https://dev.mysql.com/downloads/connector/j/
选 PlatForm Independent

下载完文件名差不多是 “mysql-connector-java-8.<小版本号>.jar”

然后写一个JDBC小的程序(需要数据库提前建好表)
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.lang.ClassNotFoundException; public class jdbcer {
public static final String DRIVER = "com.mysql.cj.jdbc.Driver";
public static final String URL = "jdbc:mysql://localhost:3306/zk_stu?useSSL=false&serverTimezone=UTC";
public static final String USER = "root";
public static final String PASSWD = "yourpasswd"; public static void main(String[] args) throws Exception{
Class.forName("com.mysql.cj.jdbc.Driver");
Connection conn = DriverManager.getConnection(URL, USER, PASSWD);
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM 路人194班"); while (rs.next()){
System.out.println(rs.getString("学号") + " 姓名:" + rs.getString("姓名"));
}
} }
把MySQL8的JDBC驱动和jdbcer.java放在同一目录
例子如下(tab键可以智能补全路径)
编译
javac -encoding UTF-8 -cp mysql-connector-java-8.0.16.jar; jdbcer.java
运行
java -cp mysql-connector-java-8.0.16.jar; jdbcer
如果不加cp参数,就会出现类的加载抛出异常(运行错误:java.lang.ClassNotFoundException) -encoding用于指定编码格式,用UTF-8来避免中文乱码
-cp 即classpath是依赖路径,多个包可以用逗号分割,最后用分号表示classpath结束(分号绝不能少)
分为两种:目录和jar包
- 目录型:
fie.java依赖于目录dirA和dirB下的一些class文件,这种就是目录型的
编译: javac -cp dirA,dirB; fie.java
- Jar包型:
fig.java依赖于1.jar和2.jar(尽管这两个包在同一个目录dirC下)
编译: javac -cp 1.jar, 2.jar; fig.java
注意:直接 javac -cp dirC; fig.java 是没用的,因为jar包其实也是一种“目录”,javac编译器要打开jar包才能看到里面的内容
记得不要漏掉逗号和分号
两者运行都要加classpath,即-cp参数 当然可以编译后直接运行,把两个命令写成一句
javac -encoding UTF-8 -cp mysql-connector-java-8.0.16.jar; jdbcer.java && java -cp mysql-connector-java-8.0.16.jar; jdbcer
MySQL8和MySQL5的密码策略和JDBC驱动名等都不一样,最后附上:javac中使用-d,以及javac / java中使用-cp介绍
这里丢个读取Jar内sqlite数据库(db格式文件)的例子:
private Connection initConnection() {
String url = "jdbc:sqlite:" + ":resource:" + getClass().getResource("resources/my.db").toString();
System.out.println("url: " + url);
Properties config = new Properties();
config.setProperty("open_mode", "1"); // readonly
try {
Class.forName("org.sqlite.JDBC");
conn = DriverManager.getConnection(url, config);
System.out.println("Connected! Version: " + conn.getMetaData().getDatabaseProductVersion());
} catch (Exception e) {
e.printStackTrace();
System.exit(-1);
}
return conn;
}
目录结构
jar内

未打包时

Manifest-Version: 1.0
Main-Class: demo.sqliteJDBC
Class-Path: lib/sqlite-jdbc-3.30.1.jar
MANIFEST.MF

ps. MF这个文件最后必须有个空行
打包命令
jar cvfm sqliteDemo.jar ./MANIFEST.MF -C bin/ .
执行命令
java -jar .\sqliteDemo.jar
java命令行执行程序解决依赖外部jar包的问题
转载波波仔86 最后发布于2019-07-30 10:47:30
用java命令行直接执行程序,如果这个程序需要引用外部jar包。就不能单纯用java xx来执行
如果你的jar包和程序就在一个目录:
编译
javac -cp D:\yy\yy.jar,D\xx\xx.jar test.java
执行
java -cp D:\yy\yy.jar,D\xx\xx.jar test
但是往往我们依赖的包很多,要一个个填写估计就疯了。所有我们一般会把所有的外部依赖包都放在一个文件夹里,比如在D:\lib
编译
javac -Djava.ext.dirs=D:\lib test.java
执行
java -Djava.ext.dirs=D:\lib test
这个方法需要在jdk1.6以上支持
命令行编译带外部包依赖的java源文件 [以JDBC MySQL8为例]的更多相关文章
- java命令行运行带外部jar
假设:java 代码路径为com.jdw.test,其中调用了外部jar包 则需要将jar包解压后,放入com同级目录 然后再com目录启动命令行 java com.jdw.test.HelloWor ...
- 用命令行编译java并生成可执行的jar包
用命令行编译java并生成可执行的jar包 1.编写源代码. 编写源文件:CardLayoutDemo.java并保存,例如:I:\myApp\CardLayoutDemo.java.程序结构如下: ...
- 韩顺平细说Servlet视频系列意外收获之用命令行编译带有包的java类解决方案
命令行编译带有包的java类 在命令行编译这一块,基本上都是新手入门时了解一下,然后就直奔IDE而去.这样固然没错,就怕那些--.然后今天在视频中看到了这种方法,觉得可能会用到,所以就记录下来了,以备 ...
- Linux java 命令行编译 jar包
Java 命令行编译成class,然后在打包成jar文件. 编译成class javac -classpath $CLASS_PATH -d class ./src/Hello.java 可以通过ja ...
- Java无包结构命令行编译
无包结构的命令行编译运行方式 如果图片损坏,点击链接:https://www.toutiao.com/i6491250431673500173/ 利用记事本编写一段简单的代码,文件名和类名要一致. 将 ...
- Delphi的命令行编译命令
Borland出品的Delphi,有着闪电般的编译速度,但是在界面控件使用较多.工程项目较大的时候,编译一个工程仍需要一段时间,打开庞大的Delphi IDE,也需要时间.其实,在一个工程开发结束,调 ...
- 命令行编译工具NMAKE
简介 大家已经习惯于微软提供的功能强大的IDE,已经很少考虑手动编连项目了,所谓技多不压身,有空的时候还是随我一块了解一下命令行编译. C/C++/VC++程序员或有Unix/Linux编程经验应该很 ...
- 使用命令行编译打包运行自己的MapReduce程序 Hadoop2.6.0
使用命令行编译打包运行自己的MapReduce程序 Hadoop2.6.0 网上的 MapReduce WordCount 教程对于如何编译 WordCount.java 几乎是一笔带过… 而有写到的 ...
- java命令行编译运行、打包jar
过程:java文件→class文件→exe执行文件 --------------------------------------------- 一.编译:从.java生成.class (1)ecl ...
随机推荐
- 【题解】NOIP2016提高组 复赛
[题解]NOIP2016提高组 复赛 传送门: 玩具谜题 \(\text{[P1563]}\) 天天爱跑步 \(\text{[P1600]}\) 换教室 \(\text{[P1850]}\) 组合数问 ...
- ASP.NET Core快速入门(第1章:介绍与引入)--学习笔记
课程链接:http://video.jessetalk.cn/course/explore 良心课程,大家一起来学习哈! 任务1:课程介绍 1.介绍与引入 2.配置管理 3.依赖注入 4.ASP.NE ...
- Winform 美化
首先,我们先来实现主界面的扁平化 此处分为两个步骤,第一步是更改winform自带的MainForm窗体属性,第二步是添加窗体事件. 将主窗体FormBorderStyle更改为None,这样就得到了 ...
- python匹配ip地址
ip地址是用3个'.'号作为分隔符,分割4个数字,每个数字的取值在[0,255],一般日志文件中的ip地址都是有效的ip地址,不需要我们再去验证,因此,若从日志文件中提取ip,那么可以简单写成这样: ...
- Linux链接文件——软连接和硬链接
Linux链接文件——软连接和硬链接 摘要:本文主要介绍了Linux系统中的链接文件. 文件系统 在Linux系统中,将文件分为两个部分:用户数据和元数据. 元数据(inode) 元数据即文件的索引节 ...
- C#中将long浮点数格式化为{H:min:s.ms}格式的字符串的方法
场景 表示时间的数据格式为浮点数,如下: 需要将其格式化为{H:min:s.ms}格式的字符串,效果如下: 注: 博客主页:https://blog.csdn.net/badao_liumang_qi ...
- Java中的参数验证(非Spring版)
1. Java中的参数验证(非Spring版) 1.1. 前言 为什么我总遇到这种非正常问题,我们知道很多时候我们的参数校验都是放在controller层的传入参数进行校验,我们常用的校验方式就是引入 ...
- Promise的三兄弟:all(), race()以及allSettled()
摘要: 玩转Promise. 原文:Promise 中的三兄弟 .all(), .race(), .allSettled() 译者:前端小智 Fundebug经授权转载,版权归原作者所有. 从ES6 ...
- tornado中的options常用姿势
tornado是facebook开源的非阻塞web容器,类似java的netty,tornado.options是负责解析tornado容器的全局参数的,同时也能够解析命令行传递的参数和从配置文件中解 ...
- Win2003下安装PHP5.2.0+MySql5.0.27+PHPMyAdmin2.9.1的配置方法
先下载所需要安装的东东~~ PHP 5.2.0 官方下载地址:http://www.php.net/downloads.php mysql-5.0.27 官方下载地址:http://dev.mysql ...