摘要:做到每个敲下的按键每次鼠标的点击每次手机屏幕的触碰,都能产生价值开发环境为了开发应用级的程序,整个开发链比较繁琐复杂,所以会需要更多的时间来掌握。注有关详细信息请使用重新编译。执行文件执行结果,打印表信息如下至此,与成功实现了数据交互。
ArthurSlog
SLog-5
Year·1
Guangzhou·China
July 11th 2018
做到每个敲下的按键、每次鼠标的点击、每次手机屏幕的触碰,都能产生价值
开发环境MacOS(High Sierra 10.13.5)Java为了开发应用级的程序,整个开发链比较繁琐复杂,所以会需要更多的时间来掌握。
老规则,让我们明确一下需要的信息Mysql官方手册
打开命令行,测试一下java,如果提示没有安装JDK,移步JavaJDK下载
安装完JDK,测试一下安装是否完整
java -version
java version "10.0.1" 2018-04-17 Java(TM) SE Runtime Environment 18.3 (build 10.0.1+10) Java HotSpot(TM) 64-Bit Server VM 18.3 (build 10.0.1+10, mixed mode)
javac -version
javac 10.0.1
在macOS中,JDK安装路径是/Library/Java/JavaVirtualMachines/jdk-10.jdk/Contents/Home
在macOS中,JRE安装路径是/Library/Internet Plug-Ins/JavaAppletPlugin.plugin/Contents/Home
下载Connector / J,选择platform Independent,选择Platform Independent (Architecture Independent), ZIP Archive下载
下载好Connector / J后解压文件得到文件夹,配置 CLASSPATH
export CLASSPATH=~/Downloads/mysql-connector-java-8.0.11.jar:$CLASSPATH
下面是完整代码
LoadDriver.java
import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.sql.Statement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; // assume that conn is an already created JDBC connection (see previous examples) public class LoadDriver { public static void main(String[] args) { try { // The newInstance() call is a work around for some // broken Java implementations Class.forName("com.mysql.cj.jdbc.Driver").newInstance(); Connection conn = null; try { conn = DriverManager.getConnection("jdbc:mysql://localhost/my_db?" + "user=root&password=88888888"); // Do something with the Connection Statement stmt = null; ResultSet rs = null; try { stmt = conn.createStatement(); rs = stmt.executeQuery("SELECT * FROM Account"); // or alternatively, if you don"t know ahead of time that // the query will be a SELECT... if (stmt.execute("SELECT * FROM Account")) { rs = stmt.getResultSet(); } // Now do something with the ResultSet .... ResultSetMetaData rsmd = rs.getMetaData(); int columnsNumber = rsmd.getColumnCount(); while (rs.next()) { for (int i = 1; i <= columnsNumber; i++) { if (i > 1) System.out.print(", "); String columnValue = rs.getString(i); System.out.print(columnValue + " " + rsmd.getColumnName(i)); } System.out.println(""); } } catch (SQLException ex){ // handle any errors System.out.println("SQLException: " + ex.getMessage()); System.out.println("SQLState: " + ex.getSQLState()); System.out.println("VendorError: " + ex.getErrorCode()); } finally { // it is a good idea to release // resources in a finally{} block // in reverse-order of their creation // if they are no-longer needed if (rs != null) { try { rs.close(); } catch (SQLException sqlEx) { } // ignore rs = null; } if (stmt != null) { try { stmt.close(); } catch (SQLException sqlEx) { } // ignore stmt = null; } } } catch (SQLException ex) { // handle any errors System.out.println("SQLException: " + ex.getMessage()); System.out.println("SQLState: " + ex.getSQLState()); System.out.println("VendorError: " + ex.getErrorCode()); } } catch (Exception ex) { // handle the error System.out.println("Exception: " + ex.getMessage()); } } }执行流程如下:
用java应用程序注册你的mysql jdbc驱动程序,参考Mysql/JDBC执行SQL手册
Class.forName("com.mysql.cj.jdbc.Driver").newInstance()
连接数据库
conn =DriverManager.getConnection("jdbc:mysql://localhost/my_db?" + "user=root&password=88888888")
获得连接对象,并执行SQL指令
Statement stmt = null; ResultSet rs = null; stmt = conn.createStatement(); rs = stmt.executeQuery("SELECT * FROM Account");
获得SQL执行结果,对结果进行打印
ResultSetMetaData rsmd = rs.getMetaData(); int columnsNumber = rsmd.getColumnCount(); while (rs.next()) { for (int i = 1; i <= columnsNumber; i++) { if (i > 1) System.out.print(", "); String columnValue = rs.getString(i); System.out.print(columnValue + " " + rsmd.getColumnName(i)); } System.out.println(""); }
打印SQL结果
ResultSet resultSet = statement.executeQuery("SELECT * from foo"); ResultSetMetaData rsmd = resultSet.getMetaData(); int columnsNumber = rsmd.getColumnCount(); while (resultSet.next()) { for (int i = 1; i <= columnsNumber; i++) { if (i > 1) System.out.print(", "); String columnValue = resultSet.getString(i); System.out.print(columnValue + " " + rsmd.getColumnName(i)); } System.out.println(""); }
切换到LoadDriver.java文件路径下,编译LoadDriver.java文件
javac LoadDriver.java
编译生成LoadDriver.class,编译提示
注: LoadDriver.java使用或覆盖了已过时的 API。 注: 有关详细信息, 请使用 -Xlint:deprecation 重新编译。
执行LoadDriver.class文件
java LoadDriver
执行结果,打印Account表信息如下:
1 ID, ArthurSlog AccountName, ArthurSlog Password
至此,Java与MySQL成功实现了数据交互。
欢迎关注我的微信公众号 ArthurSlog 如果你喜欢我的文章 欢迎点赞 留言 谢谢文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/76817.html
摘要:现在,对接文件已经到位接下来测试数据库,如果还没安装或者安装了还没配置,移步数据库配置,完成数据库的安装和配置或者在官方下载,安装官方手册安装。 ArthurSlog SLog-3 Year·1 Guangzhou·China July 9th 2018 showImg(https://segmentfault.com/img/remote/1460000016093266?w=2...
阅读 791·2021-09-22 16:01
阅读 2083·2021-08-20 09:37
阅读 1693·2019-08-30 15:54
阅读 1689·2019-08-30 15:44
阅读 826·2019-08-28 18:23
阅读 3005·2019-08-26 12:17
阅读 1004·2019-08-26 11:56
阅读 1539·2019-08-23 16:20