Hướng dẫn mysql-connector/j maven - mysql-connector / j maven
Để kết nối Java với MySQL bằng JDBC, giả sử bạn đã tạo bảng trong MySQL, bạn cần làm theo 4 bước sau: kết nối Java với MySQL bằng JDBC, giả sử bạn đã tạo bảng trong MySQL, bạn cần làm theo 4 bước sau: Nội dung chính
Chi tiết về việc kết nối ứng dụng Java với cơ sở dữ liệu MySQL bằng JDBC được thể hiển trong ví dụ dưới đây. Tạo bảng 'student' trong cơ sở dữ liệu có tên 'testdb' trong MySQL với câu lệnh như sau: CREATE TABLE student ( id INT NOT NULL, name VARCHAR (32) NOT NULL, address VARCHAR (32) NOT NULL, PRIMARY KEY (id) ); Insert vài dòng dữ liệu cho bảng 'student' INSERT INTO student(id, name, address) VALUES (1, "Công", "Hanoi"); INSERT INTO student(id, name, address) VALUES (2, "Dung", "Vinhphuc"); INSERT INTO student(id, name, address) VALUES (3, "Ngôn", "Danang"); INSERT INTO student(id, name, address) VALUES (4, "Hạnh", "Hanoi") Sau khi thực thi các câu lệnh trên chúng ta có được dữ liệu như sau: Tạo chương trình để kết nối và hiển thị dữ liệu của bảng 'student' ra màn hình như sau: File: ConnectMysqlExample.java package vn.viettuts.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class ConnectMysqlExample { private static String DB_URL = "jdbc:mysql://localhost:3306/testdb"; private static String USER_NAME = "root"; private static String PASSWORD = "1234567890"; /** * main * * @author viettuts.vn * @param args */ public static void main(String args[]) { try { // connnect to database 'testdb' Connection conn = getConnection(DB_URL, USER_NAME, PASSWORD); // crate statement Statement stmt = conn.createStatement(); // get data from table 'student' ResultSet rs = stmt.executeQuery("select * from student"); // show data while (rs.next()) { System.out.println(rs.getInt(1) + " " + rs.getString(2) + " " + rs.getString(3)); } // close connection conn.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * create connection * * @author viettuts.vn * @param dbURL: database's url * @param userName: username is used to login * @param password: password is used to login * @return connection */ public static Connection getConnection(String dbURL, String userName, String password) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(dbURL, userName, password); System.out.println("connect successfully!"); } catch (Exception ex) { System.out.println("connect failure!"); ex.printStackTrace(); } return conn; } } Kết quả: connect successfully! 1 Công Hanoi 2 Dung Vinhphuc 3 Ngôn Danang 4 Hạnh Hanoi Tham khảo bài học: Cài đặt MySQL Dưới đây là 6 video hướng dẫn chi tiết về việc kết nối Java tới MySQL. Ngoài việc thực hiện trên cosole thì còn hướng dẫn thực hiện các lệnh truy vấn trên giao diện. Các video có tiếng hơi bé, các bạn mở loa to lên hoặc đeo tai nghe vào nhé. Phần 1: Chuẩn bị & thực hiện kết nối Download mysql-connector-java-5.1.29-bin.jar (hoặc tại đây) Copy vào project, ấn chuột phải chọn Built Path/ Add to Built PahtPhần 2: Thực hiện lệnh truy vấn SelectPhần 3: Thực hiện lệnh truy vấn inset, update, deletePhần 4: Thiết kế giao diện cho JFrame kết nối dữ liệuPhần 5: Load data lên JTableDưới đây là 6 video hướng dẫn chi tiết về việc kết nối Java tới MySQL. Ngoài việc thực hiện trên cosole thì còn hướng dẫn thực hiện các lệnh truy vấn trên giao diện. Các video có tiếng hơi bé, các bạn mở loa to lên hoặc đeo tai nghe vào nhé. Nội dung chính
Phần 1: Chuẩn bị & thực hiện kết nối Download mysql-connector-java-5.1.29-bin.jar (hoặc tại đây) Copy vào project, ấn chuột phải chọn Built Path/ Add to Built PahtPhần 2: Thực hiện lệnh truy vấn SelectPhần 3: Thực hiện lệnh truy vấn inset, update, deletePhần 4: Thiết kế giao diện cho JFrame kết nối dữ liệuPhần 5: Load data lên JTablePhần 6: Bắt sự kiện JButton thực hiện delete, update, add (insert) Code: https://github.com/nguyenvanquan7826/TUT/tree/master/ConnectDatabaseJava Bài viết được sự cho phép của tác giả Kiên Nguyễn Chào các bạn, hiện nay có rất nhiều công cụ hỗ trợ việc lập trình rất tốt. Tiêu biểu trong số đó phải kể đến các sản phẩm của JetBrains với những tính năng ưu việt. Nhưng không vì thế mà các công cụ miễn phí mất đi vị trí của nó. Việc kết nối đến cơ sở dữ liệu trong IntelliJ Idea (một sản phẩm của JetBrains) như trong bài viết trước mình đã hướng dẫn là tính năng chỉ có ở phiên bản trả phí (phiên bản Ultimate).cách kết nối đến database MySQL trong Eclipse – một công cụ hoàn toàn miễn phí để có thể làm việc tương tự mà các bạn không phải trả phí như với IntelliJ. Chính vì vậy mà trong bài viết này, mình sẽ hướng dẫn với các bạn cách kết nối đến database MySQL trong Eclipse – một công cụ hoàn toàn miễn phí để có thể làm việc tương tự mà các bạn không phải trả phí như với IntelliJ. Xem thêm Việc làm database, việc làm mysql hấp dẫn trên TopDev Đầu tiên các bạn hãy mở Eclipse lên, ở đây mình dùng phiên bản + Bước 1: Đầu tiên các bạn hãy mở Eclipse lên, ở đây mình dùng phiên bản
INSERT INTO student(id, name, address) VALUES (1, "Công", "Hanoi"); INSERT INTO student(id, name, address) VALUES (2, "Dung", "Vinhphuc"); INSERT INTO student(id, name, address) VALUES (3, "Ngôn", "Danang"); INSERT INTO student(id, name, address) VALUES (4, "Hạnh", "Hanoi")1 như hình bên dưới. Sau đó bấm INSERT INTO student(id, name, address) VALUES (1, "Công", "Hanoi"); INSERT INTO student(id, name, address) VALUES (2, "Dung", "Vinhphuc"); INSERT INTO student(id, name, address) VALUES (3, "Ngôn", "Danang"); INSERT INTO student(id, name, address) VALUES (4, "Hạnh", "Hanoi")2 để tiếp tục. + Bước 2: Sau khi mở INSERT INTO student(id, name, address) VALUES (1, "Công", "Hanoi"); INSERT INTO student(id, name, address) VALUES (2, "Dung", "Vinhphuc"); INSERT INTO student(id, name, address) VALUES (3, "Ngôn", "Danang"); INSERT INTO student(id, name, address) VALUES (4, "Hạnh", "Hanoi")1 trong Eclipse.
(3) Khu vực chúng ta có thể viết câu query hoặc xem kết quả của các câu query và các thông tin liên quan. Bây giờ chúng ta sẽ tạo một kết nối mới đến một cơ sở dữ liệu có sẵn với hệ quản trị cơ sở dữ liệu MySQL Server. + Bước 4: Bây giờ chúng ta sẽ tạo một kết nối mới đến một cơ sở dữ liệu có sẵn với hệ quản trị cơ sở dữ liệu MySQL Server. Các bạn chuột phải vào INSERT INTO student(id, name, address) VALUES (1, "Công", "Hanoi"); INSERT INTO student(id, name, address) VALUES (2, "Dung", "Vinhphuc"); INSERT INTO student(id, name, address) VALUES (3, "Ngôn", "Danang"); INSERT INTO student(id, name, address) VALUES (4, "Hạnh", "Hanoi")8 sẽ mở lên như sau:
(3) Bấm + Bước 5: Ở bước này chúng ta sẽ đi vào chi tiết các thông tin cho việc kết nối hệ quản trị cơ sở dữ liệu. Note: Ở đây mình dùng package vn.viettuts.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class ConnectMysqlExample { private static String DB_URL = "jdbc:mysql://localhost:3306/testdb"; private static String USER_NAME = "root"; private static String PASSWORD = "1234567890"; /** * main * * @author viettuts.vn * @param args */ public static void main(String args[]) { try { // connnect to database 'testdb' Connection conn = getConnection(DB_URL, USER_NAME, PASSWORD); // crate statement Statement stmt = conn.createStatement(); // get data from table 'student' ResultSet rs = stmt.executeQuery("select * from student"); // show data while (rs.next()) { System.out.println(rs.getInt(1) + " " + rs.getString(2) + " " + rs.getString(3)); } // close connection conn.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * create connection * * @author viettuts.vn * @param dbURL: database's url * @param userName: username is used to login * @param password: password is used to login * @return connection */ public static Connection getConnection(String dbURL, String userName, String password) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(dbURL, userName, password); System.out.println("connect successfully!"); } catch (Exception ex) { System.out.println("connect failure!"); ex.printStackTrace(); } return conn; } }0 và package vn.viettuts.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class ConnectMysqlExample { private static String DB_URL = "jdbc:mysql://localhost:3306/testdb"; private static String USER_NAME = "root"; private static String PASSWORD = "1234567890"; /** * main * * @author viettuts.vn * @param args */ public static void main(String args[]) { try { // connnect to database 'testdb' Connection conn = getConnection(DB_URL, USER_NAME, PASSWORD); // crate statement Statement stmt = conn.createStatement(); // get data from table 'student' ResultSet rs = stmt.executeQuery("select * from student"); // show data while (rs.next()) { System.out.println(rs.getInt(1) + " " + rs.getString(2) + " " + rs.getString(3)); } // close connection conn.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * create connection * * @author viettuts.vn * @param dbURL: database's url * @param userName: username is used to login * @param password: password is used to login * @return connection */ public static Connection getConnection(String dbURL, String userName, String password) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(dbURL, userName, password); System.out.println("connect successfully!"); } catch (Exception ex) { System.out.println("connect failure!"); ex.printStackTrace(); } return conn; } }1 nên mình phải download phiên bản phù hợp. Các bạn có thể download phiên bản phù hợp của thư viện với MySQL Server tại đây:
+ Bước 6: Sau khi download file thư viện về, ở bước này các bạn vào tab package vn.viettuts.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class ConnectMysqlExample { private static String DB_URL = "jdbc:mysql://localhost:3306/testdb"; private static String USER_NAME = "root"; private static String PASSWORD = "1234567890"; /** * main * * @author viettuts.vn * @param args */ public static void main(String args[]) { try { // connnect to database 'testdb' Connection conn = getConnection(DB_URL, USER_NAME, PASSWORD); // crate statement Statement stmt = conn.createStatement(); // get data from table 'student' ResultSet rs = stmt.executeQuery("select * from student"); // show data while (rs.next()) { System.out.println(rs.getInt(1) + " " + rs.getString(2) + " " + rs.getString(3)); } // close connection conn.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * create connection * * @author viettuts.vn * @param dbURL: database's url * @param userName: username is used to login * @param password: password is used to login * @return connection */ public static Connection getConnection(String dbURL, String userName, String password) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(dbURL, userName, password); System.out.println("connect successfully!"); } catch (Exception ex) { System.out.println("connect failure!"); ex.printStackTrace(); } return conn; } }2 => package vn.viettuts.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class ConnectMysqlExample { private static String DB_URL = "jdbc:mysql://localhost:3306/testdb"; private static String USER_NAME = "root"; private static String PASSWORD = "1234567890"; /** * main * * @author viettuts.vn * @param args */ public static void main(String args[]) { try { // connnect to database 'testdb' Connection conn = getConnection(DB_URL, USER_NAME, PASSWORD); // crate statement Statement stmt = conn.createStatement(); // get data from table 'student' ResultSet rs = stmt.executeQuery("select * from student"); // show data while (rs.next()) { System.out.println(rs.getInt(1) + " " + rs.getString(2) + " " + rs.getString(3)); } // close connection conn.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * create connection * * @author viettuts.vn * @param dbURL: database's url * @param userName: username is used to login * @param password: password is used to login * @return connection */ public static Connection getConnection(String dbURL, String userName, String password) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(dbURL, userName, password); System.out.println("connect successfully!"); } catch (Exception ex) { System.out.println("connect failure!"); ex.printStackTrace(); } return conn; } }3 vào trỏ đến file vừa download về. => Sau đó bấm package vn.viettuts.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class ConnectMysqlExample { private static String DB_URL = "jdbc:mysql://localhost:3306/testdb"; private static String USER_NAME = "root"; private static String PASSWORD = "1234567890"; /** * main * * @author viettuts.vn * @param args */ public static void main(String args[]) { try { // connnect to database 'testdb' Connection conn = getConnection(DB_URL, USER_NAME, PASSWORD); // crate statement Statement stmt = conn.createStatement(); // get data from table 'student' ResultSet rs = stmt.executeQuery("select * from student"); // show data while (rs.next()) { System.out.println(rs.getInt(1) + " " + rs.getString(2) + " " + rs.getString(3)); } // close connection conn.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * create connection * * @author viettuts.vn * @param dbURL: database's url * @param userName: username is used to login * @param password: password is used to login * @return connection */ public static Connection getConnection(String dbURL, String userName, String password) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(dbURL, userName, password); System.out.println("connect successfully!"); } catch (Exception ex) { System.out.println("connect failure!"); ex.printStackTrace(); } return conn; } }4 để hoàn tất việc thêm MySQL Driver.
+ Bước 7: Ở đây sau khi kết nối giả sử mình muốn xem dữ liệu của bảng package vn.viettuts.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class ConnectMysqlExample { private static String DB_URL = "jdbc:mysql://localhost:3306/testdb"; private static String USER_NAME = "root"; private static String PASSWORD = "1234567890"; /** * main * * @author viettuts.vn * @param args */ public static void main(String args[]) { try { // connnect to database 'testdb' Connection conn = getConnection(DB_URL, USER_NAME, PASSWORD); // crate statement Statement stmt = conn.createStatement(); // get data from table 'student' ResultSet rs = stmt.executeQuery("select * from student"); // show data while (rs.next()) { System.out.println(rs.getInt(1) + " " + rs.getString(2) + " " + rs.getString(3)); } // close connection conn.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * create connection * * @author viettuts.vn * @param dbURL: database's url * @param userName: username is used to login * @param password: password is used to login * @return connection */ public static Connection getConnection(String dbURL, String userName, String password) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(dbURL, userName, password); System.out.println("connect successfully!"); } catch (Exception ex) { System.out.println("connect failure!"); ex.printStackTrace(); } return conn; } }9 mình có thể chuột phải vào bảng: connect successfully! 1 Công Hanoi 2 Dung Vinhphuc 3 Ngôn Danang 4 Hạnh Hanoi0 => connect successfully! 1 Công Hanoi 2 Dung Vinhphuc 3 Ngôn Danang 4 Hạnh Hanoi1. Và đây chính là dữ liệu trong bảng package vn.viettuts.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class ConnectMysqlExample { private static String DB_URL = "jdbc:mysql://localhost:3306/testdb"; private static String USER_NAME = "root"; private static String PASSWORD = "1234567890"; /** * main * * @author viettuts.vn * @param args */ public static void main(String args[]) { try { // connnect to database 'testdb' Connection conn = getConnection(DB_URL, USER_NAME, PASSWORD); // crate statement Statement stmt = conn.createStatement(); // get data from table 'student' ResultSet rs = stmt.executeQuery("select * from student"); // show data while (rs.next()) { System.out.println(rs.getInt(1) + " " + rs.getString(2) + " " + rs.getString(3)); } // close connection conn.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * create connection * * @author viettuts.vn * @param dbURL: database's url * @param userName: username is used to login * @param password: password is used to login * @return connection */ public static Connection getConnection(String dbURL, String userName, String password) { Connection conn = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(dbURL, userName, password); System.out.println("connect successfully!"); } catch (Exception ex) { System.out.println("connect failure!"); ex.printStackTrace(); } return conn; } }9. Các bạn có thể tìm hiểu thêm các thao tác với bảng, cơ sở dữ liệu nhé.
Lời KếtTrên đây là các bước giúp bạn kết nối đến Database MySQL trong Eclipse, cũng khá đơn giản phải không nào!kết nối đến Database MySQL trong Eclipse, cũng khá đơn giản phải không nào! Vậy là trong bài viết này mình đã hướng dẫn với các bạn cách kết nối đến hệ quản trị cơ sở dữ liệu MySQL Server để chúng ta có thể thao tác với dữ liệu trực tiếp trên IDE thay vì sử dụng thêm công cụ MySQL Workbench rồi ha. Thực tế việc thao tác với cơ sở trực tiếp trên các IDE như thế này sẽ có một số hạn chế so với các công cụ chuyên dụng. Song, nó sẽ giúp chúng ta thuận tiện hơn trong nhiều trường hợp. Cảm ơn và hẹn gặp lại các bạn trong bài viết tiếp theo nha.! Bài viết gốc được đăng tải tại blogchiasekienthuc.com Có thể bạn quan tâm:
|