完整java开发中JDBC连接数据库代码和步骤

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:
  1. JDBC连接数据库
  2. •创建一个以JDBC连接数据库的程序,包含7个步骤:
  3. 1、加载JDBC驱动程序:
  4. 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),
  5. 这通过java.lang.Class类的静态方法forName(String className)实现。
  6. 例如:
  7. try{
  8. //加载MySql的驱动类
  9. Class.forName("com.mysql.jdbc.Driver") ;
  10. }catch(ClassNotFoundException e){
  11. System.out.println("找不到驱动程序类 ,加载驱动失败!");
  12. e.printStackTrace() ;
  13. }
  14. 成功加载后,会将Driver类的实例注册到DriverManager类中。
  15. 2、提供JDBC连接的URL
  16. •连接URL定义了连接数据库时的协议、子协议、数据源标识。
  17. •书写形式:协议:子协议:数据源标识
  18. 协议:在JDBC中总是以jdbc开始
  19. 子协议:是桥连接的驱动程序或是数据库管理系统名称。
  20. 数据源标识:标记找到数据库来源的地址与连接端口。
  21. 例如:(MySql的连接URL)
  22. jdbc:mysql:
  23. //localhost:3306/test?useUnicode=true&characterEncoding=gbk ;
  24. useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为
  25. gb2312或GBK,本参数必须设置为true 。characterEncoding=gbk:字符编码方式。
  26. 3、创建数据库的连接
  27. •要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象,
  28. 该对象就代表一个数据库的连接。
  29. •使用DriverManager的getConnectin(String url , String username ,
  30. String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和
  31. 密码来获得。
  32. 例如:
  33. //连接MySql数据库,用户名和密码都是root
  34. String url = "jdbc:mysql://localhost:3306/test" ;
  35. String username = "root" ;
  36. String password = "root" ;
  37. try{
  38. Connection con =
  39. DriverManager.getConnection(url , username , password ) ;
  40. }catch(SQLException se){
  41. System.out.println("数据库连接失败!");
  42. se.printStackTrace() ;
  43. }
  44. 4、创建一个Statement
  45. •要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3
  46. 种类型:
  47. 1、执行静态SQL语句。通常通过Statement实例实现。
  48. 2、执行动态SQL语句。通常通过PreparedStatement实例实现。
  49. 3、执行数据库存储过程。通常通过CallableStatement实例实现。
  50. 具体的实现方式:
  51. Statement stmt = con.createStatement() ;
  52. PreparedStatement pstmt = con.prepareStatement(sql) ;
  53. CallableStatement cstmt =
  54. con.prepareCall("{CALL demoSp(? , ?)}") ;
  55. 5、执行SQL语句
  56. Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate
  57. 和execute
  58. 1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句
  59. ,返回一个结果集(ResultSet)对象。
  60. 2int executeUpdate(String sqlString):用于执行INSERT、UPDATE或
  61. DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等
  62. 3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的
  63. 语句。
  64. 具体实现的代码:
  65. ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ;
  66. int rows = stmt.executeUpdate("INSERT INTO ...") ;
  67. boolean flag = stmt.execute(String sql) ;
  68. 6、处理结果
  69. 两种情况:
  70. 1、执行更新返回的是本次操作影响到的记录数。
  71. 2、执行查询返回的结果是一个ResultSet对象。
  72. • ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些
  73. 行中数据的访问。
  74. • 使用结果集(ResultSet)对象的访问方法获取数据:
  75. while(rs.next()){
  76. String name = rs.getString("name") ;
  77. String pass = rs.getString(1) ; // 此方法比较高效
  78. }
  79. (列是从左到右编号的,并且从列1开始)
  80. 7、关闭JDBC对象
  81. 操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声
  82. 明顺序相反:
  83. 1、关闭记录集
  84. 2、关闭声明
  85. 3、关闭连接对象
  86. if(rs != null){ // 关闭记录集
  87. try{
  88. rs.close() ;
  89. }catch(SQLException e){
  90. e.printStackTrace() ;
  91. }
  92. }
  93. if(stmt != null){ // 关闭声明
  94. try{
  95. stmt.close() ;
  96. }catch(SQLException e){
  97. e.printStackTrace() ;
  98. }
  99. }
  100. if(conn != null){ // 关闭连接对象
  101. try{
  102. conn.close() ;
  103. }catch(SQLException e){
  104. e.printStackTrace() ;
  105. }
  106. }
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6天前
|
传感器 监控 Java
Java代码结构解析:类、方法、主函数(1分钟解剖室)
### Java代码结构简介 掌握Java代码结构如同拥有程序世界的建筑蓝图,类、方法和主函数构成“黄金三角”。类是独立的容器,承载成员变量和方法;方法实现特定功能,参数控制输入环境;主函数是程序入口。常见错误包括类名与文件名不匹配、忘记static修饰符和花括号未闭合。通过实战案例学习电商系统、游戏角色控制和物联网设备监控,理解类的作用、方法类型和主函数任务,避免典型错误,逐步提升编程能力。 **脑图速记法**:类如太空站,方法即舱段;main是发射台,static不能换;文件名对仗,括号要成双;参数是坐标,void不返航。
26 5
|
24天前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
122 25
|
1月前
|
JavaScript NoSQL Java
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
179 96
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
|
1月前
|
关系型数据库 MySQL 数据库连接
Unity连接Mysql数据库 增 删 改 查
在 Unity 中连接 MySQL 数据库,需使用 MySQL Connector/NET 作为数据库连接驱动,通过提供服务器地址、端口、用户名和密码等信息建立 TCP/IP 连接。代码示例展示了如何创建连接对象并执行增删改查操作,确保数据交互的实现。测试代码中,通过 `MySqlConnection` 类连接数据库,并使用 `MySqlCommand` 执行 SQL 语句,实现数据的查询、插入、删除和更新功能。
|
2月前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
2月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
90 2
|
11天前
|
监控 关系型数据库 MySQL
云数据库:从零到一,构建高可用MySQL集群
在互联网时代,数据成为企业核心资产,传统单机数据库难以满足高并发、高可用需求。云数据库通过弹性扩展、分布式架构等优势解决了这些问题,但也面临数据安全和性能优化挑战。本文介绍了如何从零开始构建高可用MySQL集群,涵盖选择云服务提供商、创建实例、配置高可用架构、数据备份恢复及性能优化等内容,并通过电商平台案例展示了具体应用。
|
18天前
|
SQL 关系型数据库 MySQL
数据库数据恢复——MySQL简介和数据恢复案例
MySQL数据库数据恢复环境&故障: 本地服务器,安装的windows server操作系统。 操作系统上部署MySQL单实例,引擎类型为innodb,表空间类型为独立表空间。该MySQL数据库没有备份,未开启binlog。 人为误操作,在用Delete命令删除数据时未添加where子句进行筛选导致全表数据被删除,删除后未对该表进行任何操作。
|
1月前
|
关系型数据库 MySQL 数据库
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
165 42
|
2月前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
486 0

热门文章

最新文章