原文来自搬砖工,如需转载请注明出处
我们常用的是java的JDBC,因此这里就以JDBC为例总结一下java数据库操作常用的一些内容
一、数据库驱动加载
首先,我们知道JDBC是以java数据库驱动为主要实现机制进行数据库操作的,每个类型的数据库都有不同的数据库驱动。常用的数据库驱动加载如下:(驱动可到官网下载)
1.Oracle8/8i/9iO数据库(thin模式)
Class.forName("Oracle.jdbc.driver.OracleDriver").newInstance();
2.mysql数据库
Class.forName("com.mysql.jdbc.Driver").newInstance();
3.DB2数据库
Class.froName("com.ibm.db2.jdbc.app.DB2Driver").newInstance();
4.Sql Server数据库
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver"); //Sql Server7.0/2000数据库 Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); //Sql Server2005/2008数据库
二、建立连接
数据库操作先需要与数据库建立连接,然后从数据库中读取我们需要的数据
1.Oracle8/8i/9iO数据库(thin模式)
String url="jdbc:oracle:thin:@localhost:1521:orcl"; String user="root"; String password="root"; Connection conn=DriverManager.getConnection(url,user,password);
2.mysql数据库
String url="jdbc:mysql://localhost:3306/testDB?user=root&password=root&useUnicode=true&characterEncoding=gb2312"; Connection conn=DriverManager.getConnection(url);
3.DB2数据库
String url="jdbc:db2://localhost:5000/sample"; String user="amdin" String password=-""; Connection conn=DriverManager.getConnection(url,user,password);
4.Sql Server数据库
String url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs"; String user="sa"; String password=""; Connection conn=DriverManager.getConnection(url,user,password);
三、执行SQL语句
根据条件进行数据库操作
//建立Statement对象 Statement stmt=conn.createStatement(); //建立PreparedStatement对象 String sql="select * from user where userName=? and password=?"; PreparedStatement pstmt=Conn.prepareStatement(sql); pstmt.setString(1,"root"); pstmt.setString(2,"root"); //做好准备工作之后就可以执行sql语句了,执行sql语句: String sql="select * from users"; ResultSet rs=stmt.executeQuery(sql); //执行动态SQL查询 ResultSet rs=pstmt.executeQuery(); //执行insert update delete等语句,先定义sql stmt.executeUpdate(sql);
四、处理结果集
把数据库查询出来的数据进行处理,得到我们需要的内容
while(rs.next) { System.out.println("你的第一个字段内容为:"+rs.getString("Name")); System.out.println("你的第二个字段内容为:"+rs.getString(2)); }
五、关闭数据库连接
操作完数据库一定要记得关闭数据库连接,不然不造成资源浪费。当连接达到一定数目的时候,读取数据库速度将会降低。
依次将ResultSet、Statement、PreparedStatement、Connection对象关闭,释放所占用的资源.
rs.close(); stmt.clost(); pstmt.close(); con.close();
六、数据库事务
事务是现代数据库理论中的核心概念之一。如果一组处理步骤或者全部发生或者一步也不执行,我们称该组处理步骤为一个事务。当所有的步骤像一个操作一样被完整地执行,我们称该事务被提交。由于其中的一部分或多步执行失败,导致没有步骤被提交,则事务必须回滚到最初的系统状态。
事务必须服从ISO/IEC所制定的ACID原则。
什么是ACID原则?
ACID是原子性(atomicity)、一致性(consistency)、隔离性 (isolation)和持久性(durability)的缩写。
1.事务的原子性表示事务执行过程中的任何失败都将导致事务所做的任何修改失效。
2.一致性表示 当事务执行失败时,所有被该事务影响的数据都应该恢复到事务执行前的状态。
3.隔离性表示在事务执行过程中对数据的修改,在事务提交之前对其他事务不可见。
4.持久性表示当系统或介质发生故障时,确保已提交事务的更新不能丢失。持久性通过数据库备份和恢复来保证。
JDBC 事务是用 Connection 对象控制的。JDBC Connection 接口( java.sql.Connection )提供了两种事务模式:自动提交和手工提交。
java.sql.Connection 提供了以下控制事务的方法:
public void setAutoCommit(boolean) public boolean getAutoCommit() public void commit() public void rollback()
使用 JDBC 事务界定时,您可以将多个 SQL 语句结合到一个事务中。JDBC 事务的一个缺点是事务的范围局限于一个数据库连接。一个 JDBC 事务不能跨越多个数据库。