欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java连接mysql的jar包没有bin(mysql可视化管理工具)

程序员文章站 2023-11-26 21:15:52
首先看一下我的基本的开发环境:操作系统:macos 10.13.5编辑器:idea 2018.3其他:mysql8.0.15、maven 3.3.9、jdk 1.8好,下面就正式开始:第一步:在ide...

首先看一下我的基本的开发环境:

操作系统:macos 10.13.5编辑器:idea 2018.3其他:mysql8.0.15、maven 3.3.9、jdk 1.8

好,下面就正式开始:

第一步:在idea中新建一个maven项目

1.使用骨架创建maven项目,此处选择:
maven-archetype-quickstart

java连接mysql的jar包没有bin(mysql可视化管理工具)

2.填入groupid和artifactid

java连接mysql的jar包没有bin(mysql可视化管理工具)

3.第一个选中maven安装的文件夹,第二个选中maven安装文件夹中的conf/settings.xml,第三个如果settings.xml中配置了localrepository,则会自动填入,若没有则会显示默认的本地仓库

java连接mysql的jar包没有bin(mysql可视化管理工具)

4.点击finish即可成功创建maven项目

java连接mysql的jar包没有bin(mysql可视化管理工具)

第二步:配置pom.xml

在pom.xml中的标签内加入要用到的jar包在仓库中的坐标

1.dom4j的jar包坐标

<dependency>
 <groupid>org.dom4j</groupid>
 <artifactid>dom4j</artifactid>
 <version>2.1.1</version>
</dependency>

2.mysql的jar包坐标

<dependency>
  <groupid>mysql</groupid>
  <artifactid>mysql-connector-java</artifactid>
  <version>8.0.13</version>
  <scope>runtime</scope>
</dependency>

第三步:创建jdbc.xml配置文件并设置

<?xml version='1.0' encoding='utf-8'?>
<accounts>
  <account>
    <url>jdbc:mysql://localhost:3306/mybase?usessl=false&servertimezone=ctt</url>
    <user>root</user>
    <password>123456</password>
  </account>
</accounts>

在src下创建jdbc.xml,这个xml文件中放置的是数据库连接时要使用的信息,包括url、root、password。因为我使用的是mysql8.0,所以url和之前版本的有所不同,其中mybase是要连接的数据库的名称,&则是&的转义字符

第四步:创建jdbcutils和testjdbcutils

在com.langsin.jdbcutil包下创建jdbcutils.java和testjdbcutils.java两个文件

java连接mysql的jar包没有bin(mysql可视化管理工具)

第五步:写入jdbcutils和testjdbcutils

package com.langsin.jdbcutil;

import org.dom4j.document;
import org.dom4j.element;
import org.dom4j.io.saxreader;
import java.sql.*;

public class jdbcutils {
 private jdbcutils {}
 private static connection con;

 static {
  try {
   //初始化mysql的driver类
   class.forname("com.mysql.cj.jdbc.driver");
   //通过dom4j得到xml文件中连接数据库的信息
   saxreader reader = new saxreader();
   document doc = reader.read("src/jdbc.xml");
   element root = doc.getrootelement();
   element ele = root.element("account");
   string url = ele.element("url");
   string user = ele.element("user");
   string password = ele.element("password");
   //连接数据库
   con = drivermanager.getconnection(url, user, password);
  } catch(exception e) {
   throw new runtimeexception(e + ",数据库连接失败!");
  }
 }

 public static connection getconnection() {
  return con;
 }

 public static void close(connection con, statement state) {
  if(con != null) {
   try {
    con.close();
   } catch (sqlexception e) {
    e.printstacktrace();
   }
  }
  if(state != null) {
   try {
    state.close();
   } catch (sqlexception e) {
    e.printstacktrace();
   }
  }
 }

 public static void close(connection con, statement state, resultset rs) {
  if(con != null) {
   try {
    con.close();
   } catch (sqlexception e) {
    e.printstacktrace();
   }
  }
  if(state != null) {
   try {
    state.close();
   } catch (sqlexception e) {
    e.printstacktrace();
   }
  }  
  if(rs != null) {
   try {
    rs.close();
   } catch (sqlexception e) {
    e.printstacktrace();
   }
  }
 }
}
package com.langsin.jdbcutil;

import java.sql.connection;
import java.sql.preparedstatement;
import java.sql.resultset;

public class testjdbcutils {
 public static void main(string[] args) {
  connection con = jdbcutils.getconnection();
  string sql = "select * from sort";
  //创建preparedstatement对象,并将sql语句发送到数据库
  preparedstatement pst = con.preparestatement(sql);
  //取得执行后的结果集
  resultset rs = pst.executequery();
  //输出sort表中第二列的所有数据
  while(rs.next()) {
   system.out.println(rs.getstring(2));
  }
  jdbcutils.close(con, pst, rs);
 }
}

好了,到此只要执行程序,控制台上就会输出我们想要的结果了。