第三十七篇:JAVA访问数据库之连接数据库
来源:互联网 发布:java 调用执行jar包 编辑:程序博客网 时间:2024/06/11 00:10
开发一个访问数据库的应用程序,首先要加载数据库的驱动程序,只需要在第一次访问数据库时加载一次,然后每次运行时创建一个Connection实例,紧接着执行操作数据库的SQL语句,并处理返回的结果集,最后在完成完成此次操作时销毁前面创建的Connection,释放与数据库的连接。
加载数据库驱动
在连接数据库之前,首先要把JDBC驱动类加载到Java虚拟机,可以使用java.lang.Class类的静态方法forName(String className)。成功加载后会将加载的驱动类注册给DriverManager类,加载失败将抛出ClassNotFoundException异常。
创建数据库连接
DriverManager类跟踪已注册的驱动程序,通过调用DriverManager类的静态方法getConnection(String url, String user, String password)可以建立与数据库的连接。3个参数依次为欲连接的数据库的路径、用户名和密码,方法返回值类型为java.sql.Connection。当调用该方法时,会搜索整个驱动程序列表,直到找到一个能够连接至数据连接字符串中指定的数据库的驱动程序为止。
执行SQL语句,得到结果集
当数据库连接建立以后,就可以使用该连接创建Statement实例,并将SQL语句传递给它所连接的数据库,并返回类型为ResultSet的对象(查询的时候),Statement实例分为3种类型:
- Statement实例:该类型的实例只能用来执行静态的SQL
- PreparedStatement实例:该类型的实例可以执行动态的SQL
- CallableStatement实例:该类型的实例可以执行数据库的存储过程
处理查询结果
对于返回的结果集,使用ResultSet对象的next()方法将光标指向下一行。最初光标位于第一行之前,因此第一次调用next()方法将光标置于第一行上,如果到达结果集的末尾,则ResultSet的next()方法会返回false,方法getXXX提供了获取当前行中某一列的值的途径,列名或列号可用于标识要从中获取数据的列。
连接示例
为了方便操作,这里我选用H2数据库,这样电脑上没有安装数据库的朋友也可以快速的构建程序,H2数据库的官网地址为:
http://www.h2database.com/html/main.html
H2是一个短小精干的嵌入式数据库引擎,主要的特性包括:
1. 免费、开源、快速
2. 嵌入式的数据库服务器,支持集群
3. 提供JDBC、ODBC访问接口,提供基于浏览器的控制台管理程序
4. Java编写,可使用GCJ和IKVM.NET编译
5. 短小精干的软件,1M左右
如电脑上已经安装了数据库,直接使用对应数据库厂商提供的驱动包即可,操作过程一致。
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
- 86
- 87
- 88
- 89
- 90
- 91
- 92
- 93
- 94
- 95
- 96
- 97
- 98
- 99
- 100
- 101
- 102
- 103
- 104
- 105
- 106
- 107
- 108
- 109
- 110
- 111
- 112
- 113
- 114
- 115
- 116
- 117
- 118
- 119
- 120
- 121
- 122
- 123
- 124
- 125
- 126
- 127
- 128
- 129
- 130
- 131
- 132
- 133
- 134
- 135
- 136
- 137
- 138
- 139
- 140
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
- 86
- 87
- 88
- 89
- 90
- 91
- 92
- 93
- 94
- 95
- 96
- 97
- 98
- 99
- 100
- 101
- 102
- 103
- 104
- 105
- 106
- 107
- 108
- 109
- 110
- 111
- 112
- 113
- 114
- 115
- 116
- 117
- 118
- 119
- 120
- 121
- 122
- 123
- 124
- 125
- 126
- 127
- 128
- 129
- 130
- 131
- 132
- 133
- 134
- 135
- 136
- 137
- 138
- 139
- 140
常用数据库驱动类及连接字符串
其中[]为需要替换的部分。
- 第三十七篇:JAVA访问数据库之连接数据库
- JAVA访问数据库之连接数据库
- 第三十六篇:JAVA访问数据库之概述
- 第三十八篇:JAVA访问数据库之增删改查(CRUD)
- Java连接数据库(JDBC)之三:java访问数据库MySQL实例
- JAVA访问数据库之概述
- 十七、Qt数据库 之 QSqlRelationalTableModel
- Java连接数据库<数据访问层>
- javaweb回顾第三篇数据库访问
- java 之连接mysql数据库
- JAVA之连接MySQL数据库
- java之连接mysql数据库
- c# 连接访问数据库
- java连接oracle数据库 -- 直接用jsp访问连接
- Java中数据库访问之JDBC
- Java数据库访问之底层:jdbc
- java之通过JDBC访问Mysql数据库
- JAVA访问数据库之增删改查
- 在Angular2.0 或 Angular4.0 中使用Jquery
- poj-1284(欧拉函数+原根)
- MySQL存储过程调试工具-dbForge Studio for MySQL
- Netty入门学习
- android gradle tools 3.X 中依赖,implement、api 指令
- 第三十七篇:JAVA访问数据库之连接数据库
- GridView频道管理
- 随机梯度下降与批梯度下降
- netscope——caffe的prototxt模型文件可视化工具
- Ionic控件 Button
- oracle 11g卸载方法
- 简谈java中的阻塞非阻塞与同步异步
- C++prime 第十五章的程序总结(购物车)
- effective C++条款三十解读