javaweb回顾第三篇数据库访问
2017-05-02 22:48
225 查看
前言:本篇主要针对数据库的操作,在这里不适用hibernate或者mybatis,用最原始的JDBC进行讲解,通过了解这些原理以后更容易理解和学习hibernate或mybatis。
首先需要下载jdbc驱动的jar包 如果不想下载在C:\Program Files (x86)\MySQL\Connector J 5.1.26位置也可以找到 如果是maven项目的话需要在pom上引入下面的依赖包
View
Code
View
Code
statement用于已经建立好数据库连接的基础上发送sql语句的对象,不带参数简单的sql语句
由于在程序中传递sql语句必须要经过预编译,包括分析,优化等,如果重复执行一条只是参数不同的sql是比较低效的,那么久可以使用preparedStatement对象对sql语句进行预编译。(推荐使用)
这个表示处理存储过程的对象。
这个主要是sql执行以后返回的结果集,然后通过next属性来转换相关的结果
executeUpdate()主要处理增删改语句,返回受影响的行数,也可以处理创建或更新数据库、以及创建或更新表结构
executeQuery()主要是用来查询的,主要针对select开头的语句
execute()表示一个特殊的执行,主要针对返回多个结果集、多个更新计数,相对来说用的少些
粘贴一下代码
JDBCHelper
事务的定义:访问并可能更新数据库中各种数据项的一个程序执行单元(笼统的将就是一段程序执行所有的sql要么同时成功,要么就全部失败回滚)
我们了解事务之前先看三个定义
脏读:一个事务正在修改某行数据但是并未提交,而另一个事务正好读取了这行数据,这就是脏读
不可重复读:一个事务读取了一行数据,在这个事务结束前另一个事务对这条数据进行修改,但是这种修改并没有提交数据库中,此时第一个事务再次读取这条数据时,出现了2次数据不一致这就是不可重复读
幻读:当一个事务读取满足条件的数据后,另一个事务却插入一条数据,当第一个事务再次读取时,发现多了一条数据。这就是幻读。
因为上面三种情况存在所以就出现了隔离级别,当然隔离级别越高效率会越低,下面是4中隔离级别
connection.TRANSACTION_READ_UNCOMMITTED:这种隔离级别最低三种情况都可能发生
connection.TRANSACTION_READ_COMMITTED:这种隔离级别避免脏读
connection.TRANSACTION_REPEATABLE_READ:这种隔离级别避免脏读和不可重读读
connection.TRANSACTION_SERIALIZABLE:这种隔离级别最高三种都可避免
当了解完这种情况以后我们就可开始进行事务处理,在默认的情况下是不执行事务的。
第一步是要开启事务:connection.setAutoCommit(false);//关闭自动提交功能(默认是true)
然后在设置隔离级别:connection.setTransactionIsolation(connection.TRANSACTION_REPEATABLE_READ);
ok有了上面的我们就可以进行事务了下面把代码贴出来,仅供参考
Transaction
main
经过测试发现
1:jdbc的简单操作
首先需要下载jdbc驱动的jar包 如果不想下载在C:\Program Files (x86)\MySQL\Connector J 5.1.26位置也可以找到 如果是maven项目的话需要在pom上引入下面的依赖包View
Code
1.1:配置连接数据库
View
Code
1.2:向数据库发起请求(增删改查)
1.2.1:statement
statement用于已经建立好数据库连接的基础上发送sql语句的对象,不带参数简单的sql语句
1.2.2:PreparedStatement
由于在程序中传递sql语句必须要经过预编译,包括分析,优化等,如果重复执行一条只是参数不同的sql是比较低效的,那么久可以使用preparedStatement对象对sql语句进行预编译。(推荐使用)
1.2.3:CallableStatement
这个表示处理存储过程的对象。
1.3:ResultSet的作用
这个主要是sql执行以后返回的结果集,然后通过next属性来转换相关的结果
1.4:executeUpdate()、executeQuery()、execute()三者区别
executeUpdate()主要处理增删改语句,返回受影响的行数,也可以处理创建或更新数据库、以及创建或更新表结构executeQuery()主要是用来查询的,主要针对select开头的语句
execute()表示一个特殊的执行,主要针对返回多个结果集、多个更新计数,相对来说用的少些
粘贴一下代码
JDBCHelper
1.4:数据库事务
事务的定义:访问并可能更新数据库中各种数据项的一个程序执行单元(笼统的将就是一段程序执行所有的sql要么同时成功,要么就全部失败回滚)我们了解事务之前先看三个定义
脏读:一个事务正在修改某行数据但是并未提交,而另一个事务正好读取了这行数据,这就是脏读
不可重复读:一个事务读取了一行数据,在这个事务结束前另一个事务对这条数据进行修改,但是这种修改并没有提交数据库中,此时第一个事务再次读取这条数据时,出现了2次数据不一致这就是不可重复读
幻读:当一个事务读取满足条件的数据后,另一个事务却插入一条数据,当第一个事务再次读取时,发现多了一条数据。这就是幻读。
因为上面三种情况存在所以就出现了隔离级别,当然隔离级别越高效率会越低,下面是4中隔离级别
connection.TRANSACTION_READ_UNCOMMITTED:这种隔离级别最低三种情况都可能发生
connection.TRANSACTION_READ_COMMITTED:这种隔离级别避免脏读
connection.TRANSACTION_REPEATABLE_READ:这种隔离级别避免脏读和不可重读读
connection.TRANSACTION_SERIALIZABLE:这种隔离级别最高三种都可避免
当了解完这种情况以后我们就可开始进行事务处理,在默认的情况下是不执行事务的。
第一步是要开启事务:connection.setAutoCommit(false);//关闭自动提交功能(默认是true)
然后在设置隔离级别:connection.setTransactionIsolation(connection.TRANSACTION_REPEATABLE_READ);
ok有了上面的我们就可以进行事务了下面把代码贴出来,仅供参考
Transaction
main
经过测试发现
相关文章推荐
- 基础知识回顾第三篇数据库访问
- 去哪网实习总结:如何有效减少对数据库的访问(JavaWeb)
- javaweb访问数据库进行查找更新
- 回顾一下Java中数据库访问,还是有一些可笑的随意性的问题。
- JAVAWEB APP访问Derby数据库
- C#基础知识回顾:2.使用DbProviderFactory实现多数据库访问
- Druid 监控JavaWeb项目的数据库访问性能
- 简单粗暴JavaWeb-第六篇:使用mybatis框架代替纯jdbc访问数据库
- JavaWeb使用JNDI访问数据库
- JAVAWEB APP访问Derby数据库
- 与数据库无关的数据库访问方法(C#)
- 为进行 ODBC 访问配置 Microsoft Jet 数据库引擎
- 用Java访问SQL Server 2000数据库
- 树型控件实现数据库的访问
- 简化JDBC的数据库访问
- 使用JDBC创建数据库访问程序
- 在JSP中访问数据库大全
- Tomcat中通过JNDI配置访问数据库
- ODP.NET oracle .NET 数据库访问[转载]
- 好久没来博客堂,发了一篇 .NET 访问 Oracle 数据库的请大家批评