麒麟v10 上部署 TiDB v5.1.2 生产环境优化实践
990
2023-07-07
MySQL如何实现JDBC
JDBC基础入门
概念
JDBC(Java DataBase Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系型数据库提供统一访问,它是由一组用Java语言编写的类和接口组成的。
JDBC 规范定义接口,具体的实现由各大数据库厂商来实现。
需要具体的数据库驱动实现才能在Java中操作数据库,因为JDBC仅仅是Java访问数据库的标准规范。每个数据库供应商都会根据其数据库的通信格式编写自己的数据库驱动程序。因此,只需掌握 JDBC 接口方法的调用,数据库厂商会提供数据库驱动。
本质
其实就是java官方提供的一套规范(接口)。用于帮助开发人员快速实现不同关系型数据库的连接!
JDBC的7个步骤
(1)导入jar包
(2)注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");登录后复制
注意:如果使用较高版本的MySQL,必须使用 com.mysql.cj.jdbc.Driver 的方式,否则会报错!
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
如果是低版本的可以使用 com.mysql.jdbc.Driver
如果还是报错,可以使用在url上面加入时区!
url=jdbc:mysql://localhost:3306/数据库名?serverTimezone=UTC
(3)获取连接
String url = "jdbc:mysql://localhost:3306/db1";Connection con = DriverManager.getConnection(url,"root","888888");登录后复制
(4)获取执行者对象
Statement stat = con.createStatement();登录后复制
(5)执行sql语句,并接收返回结果
String sql = "SELECT * FROM user";ResultSet rs = stat.executeQuery(sql);登录后复制
(6)处理结果
while(rs.next()) { System.out.println( rs.getInt("id") + "\t" + rs.getString("name"));}登录后复制
(7)释放资源
con.close();stat.close();rs.close();登录后复制
JDBC入门示例代码
Connection对象中的用户名,数据库名,密码改成你自己的哦!
public class jdbc_demo01 { public static void main(String[] args) throws ClassNotFoundException, SQLException { // 1.导入jar包 // 2.注册驱动 Class.forName("com.mysql.cj.jdbc.Driver"); // 3.获取连接 String url = "jdbc:mysql://localhost:3306/db1"; Connection con = DriverManager.getConnection(url,"root","888888"); // 4.获取执行者对象 Statement stat = con.createStatement(); // 5.执行sql语句,并且接收结果 String sql = "SELECT * FROM product"; ResultSet rs = stat.executeQuery(sql); // 6.处理结果 while(rs.next()) { System.out.println( rs.getInt("id") + "\t" + rs.getString("name") + "\t" + rs.getInt("price") + "\t" + rs.getString("brand") + "\t" + rs.getInt("stock") ); } // 7。释放资源 con.close(); stat.close(); rs.close(); }}登录后复制
结果如下:
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。