(资料图片)
JDBC(Java Database Connectivity)是一种用于在Java应用程序中访问关系型数据库的标准API。下面是一份简单的JDBC编程示例,以连接到MySQL数据库并执行查询。
在开始之前,您需要将JDBC驱动程序添加到您的Java项目中。您可以从MySQL官方网站下载JDBC驱动程序。将下载的JDBC驱动程序jar文件放在您的项目的classpath中。
要与数据库进行交互,您需要创建一个连接对象。以下是创建连接对象的示例代码:
import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;public class DatabaseConnection { private static final String URL = "jdbc:mysql://localhost:3306/mydb"; private static final String USERNAME = "username"; private static final String PASSWORD = "password"; public static Connection getConnection() throws SQLException { Connection conn = null; try { conn = DriverManager.getConnection(URL, USERNAME, PASSWORD); System.out.println("Database connection successful."); } catch (SQLException e) { System.out.println("Database connection failed."); throw e; } return conn; }}
在此示例中,我们使用MySQL数据库,并创建了一个名为DatabaseConnection
的类,该类提供了getConnection()
方法,该方法将返回连接对象。getConnection()
方法使用MySQL JDBC驱动程序提供的DriverManager.getConnection()
方法来创建连接对象。
一旦您获得了连接对象,就可以使用它来执行查询了。以下是一个简单的查询示例,查询表中的所有记录:
import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;public class QueryExample { public static void main(String[] args) { Connection conn = null; Statement stmt = null; ResultSet rs = null; try { conn = DatabaseConnection.getConnection(); stmt = conn.createStatement(); rs = stmt.executeQuery("SELECT * FROM mytable"); while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); int age = rs.getInt("age"); System.out.println("id: " + id + ", name: " + name + ", age: " + age); } } catch (SQLException e) { e.printStackTrace(); } finally { try { if (rs != null) { rs.close(); } if (stmt != null) { stmt.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } }}
在此示例中,我们使用Statement
对象执行查询,并使用ResultSet
对象处理结果集。查询返回的结果集是一组行,每行包含表中的一条记录。我们使用while
循环遍历结果集中的每一行,并提取每行中的数据。在此示例中,我们将每行的ID、名称和年龄打印到控制台。
在完成对数据库的操作后,您需要关闭连接。这可以通过调用连接对象上的close()
方法来完成,如下所示:
conn.close();
在示例代码中,我们在finally
块中关闭连接,以确保在任何情况下都会关闭连接。
X 关闭