本文目錄一覽:
CDH Mysql數據庫 JDBC driver cannot be found.
這是一個很容易出現的問題,網上很多內容將mysql驅動包上傳到不對的路徑導致出現問題。
cloudera manager添加hive時報錯找不到jdbc driver
報錯
JDBC driver cannot be found. Unable to find the JDBC database jar on host
把包放入這個目錄,注意文件名要保持一致 網上又很多需要把這個驅動包放到
cp /root/mysql-connector-java-5.1.33-bin.jar /opt/cloudera/parcels/CDH-5.4.0-1.cdh5.4.0.p0.27/lib/hive/lib/
/opt/cloudera/parcels/CDH/lib/hive/lib或者
/opt/cloudera/parcels/CDH-5.4.0-1.cdh5.4.0.p0.27/lib/hive/lib
以上其實是同一個位置
操作後問題依舊出現。
解決方法:
後來在網上找到需要將這個包放到這個路徑下就通過了(名字需要修改下)
/usr/share/java/mysql-connector-java.jar
MySQL數據庫的驅動程序文件什麼意思
數據庫驅動是不同數據庫開發商(比如oracle mysql等)為了某一種開發語言環境(比如java)能夠實現統一的數據庫調用而開發的一個程序,他的作用相當於一個翻譯人員,將Java語言中對數據庫的調用語言通過這個翻譯翻譯成各個種類的數據庫自己的數據庫語言,當然這個翻譯(數據庫驅動)是由各個開發商針對統一的接口自定義開發的
mysql的driver怎麼寫
import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Connection;import java.sql.Statement; public class MysqlDemo { public static void main(String[] args) throws Exception { Connection conn = null; String sql; // MySQL的JDBC URL編寫方式:jdbc:mysql://主機名稱:連接端口/數據庫的名稱?參數=值 // 避免中文亂碼要指定useUnicode和characterEncoding // 執行數據庫操作之前要在數據庫管理系統上創建一個數據庫,名字自己定, // 下面語句之前就要先創建javademo數據庫 String url = “jdbc:mysql://localhost:3306/javademo?” + “user=rootpassword=rootuseUnicode=truecharacterEncoding=UTF8”; try { // 之所以要使用下面這條語句,是因為要使用MySQL的驅動,所以我們要把它驅動起來, // 可以通過Class.forName把它加載進去,也可以通過初始化來驅動起來,下面三種形式都可以 Class.forName(“com.mysql.jdbc.Driver”);// 動態加載mysql驅動 // or: // com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver(); // or: // new com.mysql.jdbc.Driver(); System.out.println(“成功加載MySQL驅動程序”); // 一個Connection代表一個數據庫連接 conn = DriverManager.getConnection(url); // Statement裡面帶有很多方法,比如executeUpdate可以實現插入,更新和刪除等 Statement stmt = conn.createStatement(); sql = “create table student(NO char(20),name varchar(20),primary key(NO))”; int result = stmt.executeUpdate(sql);// executeUpdate語句會返回一個受影響的行數,如果返回-1就沒有成功 if (result != -1) { System.out.println(“創建數據表成功”); sql = “insert into student(NO,name) values(‘2012001′,’陶偉基’)”; result = stmt.executeUpdate(sql); sql = “insert into student(NO,name) values(‘2012002′,’周小俊’)”; result = stmt.executeUpdate(sql); sql = “select * from student”; ResultSet rs = stmt.executeQuery(sql);// executeQuery會返回結果的集合,否則返回空值 System.out.println(“學號\t姓名”); while (rs.next()) { System.out .println(rs.getString(1) + “\t” + rs.getString(2));// 入如果返回的是int類型可以用getInt() } } } catch (SQLException e) { System.out.println(“MySQL操作錯誤”); e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { conn.close(); } } }
原創文章,作者:LXVEO,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/316197.html