一、JDBC原理
二、Statement
execute(sql); 当不知道执行的SQL语句是什么类型的时候执行 ,返回值是boolean
executeQuery(sql); 执行查询语句
executeUpdate(sql); 执行更新语句
三、PreparedStatement
可以使用参数替代sql语句中的某些参数使用 "?"代替,他先将带参数的sql语句发送到数据库,进行编译,然后PreparedStatement会将参数发送给数据库。
在使用PreparedStatement时,在设置相应参数时,要指明参数的位置和类型,以及给出参数值
根据不同的参数类型使用不同的setXXX(参数的位置,参数值)来设置参数
例:
public void insert(Student s){
Connection con=ConnectionFactory.getConnection();//建立连接
String sql="insert into student(id,name) values(?,?)";
PreparedStatement ps=null;
try {
ps=con.prepareStatement(sql);//创建一个PreparedStatement
int index=1;
ps.setInt(index++,s.getStuId()); //为参数赋值
ps.setString(index++,s.getName());
ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}finally{
if(ps!=null)
try {
ps.close();
} catch (SQLException e) {
e.printStackTrace();
}
if(con!=null)
try {
con.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
CallableStatement是可以用非sql语句来访问数据库,他是通过调用存储过程(PL/SQL)来访问数据库的。可以直接使用连接来调用 prepareCall(...)方法,来执行这个存储过程,"..."是存储过程的名字。
对于系统时间要去数据库时间
TimeStamp 和 Date都可以保存时间
TimeStamp可以保存时、分、秒的数据,Date只保存日期年月的信息。
SQLException是检查异常必须处理要么throws ,要么try{}catch(){}
getErrorCode()可以获得错误码,可以对错误进行查询。
四、源数据
JDBC中有两种源数据,一种是数据库源数据,另一种是ResultSet源数据。
源数据就是描述存储用户数据的容器的数据结构。
ResultSet rs=ps.executeQuery(sql);
ResultSetMetaData m=rs.getMetaData();
getColumnCount(),获得实际列数
getColumnName(int colnum),获得指定列的列名
getColumnType(int colnum),获得指定列的数据类型
getColumnTypeName(int colnum),获得指定列的数据类型名
//打印结果集
public static void printRS(ResultSet rs)throws SQLException{
ResultSetMetaData rsmd = rs.getMetaData();
while(rs.next()){
for(int i = 1 ; i < = rsmd.getColumnCount() ; i++){
String colName = rsmd.getColumnName(i);
String colValue = rs.getString(i);
if(i>1){
System.out.print(",");
}
System.out.print(name+"="+value);
}
System.out.println();
}
}
五、数据库源数据
DatabaseMetaData
getURL(),获得连接数据库的URL
getDatabaseProductName() 获得数据库产品的名称
getDriverVersion() 获得JDBC驱动程序的String形式的版本号
getTables()获得数据库中该用户的所有表
getUserName() 获得数据库用户名。
六、事务(Transaction)
事务是针对原子操作的,要求原子操作不可再分,要求原子操作必须同时成功同时失败。
事务是捆绑的原子操作的边界。
JDBC中使用事务,先要使用连接调用setAutoCommite(false)方法,把自动提交(commit)置为false。打开事务就要关闭自动提交。不用事务是要把setAutoCommite(true)
在处理事务时,在发送sql语句后执行成功并确认时,就在try块中使用连接调用commit()方法来发送提交信息,
在发送sql语句后执行失败时,会在catch语句块中使用连接调用rollback()方法来发送回滚信息,也可以在需要时做回滚操作(主观原因)。
七、JDBC事务并发产生的问题和事务隔离级别
1,脏读(dirty read),读取到了没有提交的数据。
2,不可重复读(UnPrpeatable Read),两次读取到了不同的数据,就是要保持在同一时间点上两次读取到的数据相同,
不能够使查询数据时进行改变。
3,幻读(phantom),在两次查询同一时间点数据时,数据数量发生改变,要保持在同一时间点上两次读取到的数据相同。
事务隔离级别
TRANSACTION_NONE不使用事务。
TRANSACTION_READ_UNCOMMITTED 可以读取为提交数据。
TRANSACTION_READ_COMMITTED可以避免脏读,不能够读取没提交的数据,最常用的隔离级别 大部分数据库的默认隔离级别
TRANSACTION_REPEATABLE_READ可以避免脏读,重复读取,
TRANSACTION_SERIALIZABLE可以避免脏读,重复读取和幻读,(事务串行化)会降低数据库效率
以上的五个事务隔离级别都是在Connection类中定义的静态常量,使用setTransactionIsolation(int level) 方法可以设置事务隔离级别。
八,异常的处理
try{}
catch(SQLException){}
try{}
catch(Exception){}
分享到:
相关推荐
该项目是基于jsp+servlet+jdbc的学生请假信息管理系统-可用于大学生日常课设 1.后端开发技术:servlet+jdbc 2.前端技术:jsp 3.前端ui:经典蓝色ui 4.功能点描述: (1)学生 查看个人信息、查看个人的晚归记录、填写...
### IBM DB2 全球认证考试辅导资料知识点详解 #### 一、IBM DB2全球认证考试辅导资料概览 IBM DB2全球认证考试辅导资料旨在帮助考生全面掌握DB2的相关知识和技术,顺利通过DB2全球认证考试。此资料侧重于实践操作...
此外,为了数据持久化,可能采用了关系型数据库,如MySQL,配合JDBC(Java Database Connectivity)进行数据库操作,保证数据的安全存储和高效检索。同时,系统可能应用了MVC(Model-View-Controller)设计模式,将...
Java认证是全球认可的Java程序员技能评估标准,2009年的Java认证辅导资料涵盖了当时最新的Java技术,旨在帮助考生顺利通过考试并提升其Java编程能力。这些资料可能包括了Oracle Certified Associate (OCA), Oracle ...
**4.2 JDBC资料辅导(2)** - **结果集处理**: ResultSet的使用方法。 - **批处理**: 执行批量SQL语句以提高性能。 - **事务控制**: 使用Connection对象进行事务控制。 **4.3 JDBC资料辅导(3)** - **元数据**: ...
系统基于Browser/Server模式开发,应用DreamweaverMX软件,结合JSP编程技术,并以SQLServer为数据库开发工具,在Windowsxp系统中使用JDBC驱动程序进行数据库连接。论文主要阐述的是机动车驾驶员考试辅导系统的操作...
7. **CoreJava辅导资料.zip**:这可能包含Java语言的基础教程或参考资料,包括类、对象、接口、异常处理、集合框架等内容,这些都是JavaWeb开发的基础。 8. **javaWeb基础技术辅导.zip**:这个文件很可能包含了详细...
使用JDBC链接MySQL数据库,实现登录注册功能,以及对信息增删改查。...项目技术:在Java开发环境下,Eclipse编写和MVC框架搭建,前端使用JSP、Layui和Json对象实现,通过JDBC链接数据库,运行在Tomcat服务器上。
2. **架构设计**:此系统可能采用了MVC(Model-View-Controller)架构模式,将业务逻辑(Model)、数据展示(View)和用户交互(Controller)分离,以提高代码的可维护性和可扩展性。 3. **数据库管理**:数据库是...
2:发布网站留言信息:根据系统提示,发布网站的留言信息。 3:查看已发布的信息:以列表的形式查看已发布信息。 4:发布威客在线信息:根据系统提示,发布网站的留言信息。 5:查看网站成交记录:根据系统提示,...
开发人员会编写SQL语句,通过JDBC连接到数据库,执行CRUD(创建、读取、更新、删除)操作,以管理辅导员、学生和课程数据。 4. **Model-View-Controller(MVC)设计模式** MVC模式是JavaEE开发中常用的设计模式,...
《Sun认证Java2程序员考试辅导(下册)》是一份专为准备Java程序员考试的考生量身定制的参考资料。这份资料旨在帮助考生深入理解和掌握Java编程语言的核心概念,提升编程技能,以顺利通过Sun认证Java2程序员考试。下面...
3. **数据库连接**:通常使用JDBC(Java Database Connectivity)来实现数据库的连接、查询、插入等操作。在系统中,需要考虑事务管理、连接池等优化手段,以提高性能和资源利用率。 4. **会话管理**:为了保持用户...
4. 心理资源:收集各类心理辅导资料,如文章、音频、视频等,供师生学习和参考。 5. 辅导记录:记录每次心理咨询的过程,包括咨询主题、内容摘要、建议等,便于跟踪学生心理状态的变化。 6. 通知公告:发布学校...
2. **Spring MVC**:Spring MVC是Spring框架的一个模块,用于处理Web请求。它提供了模型-视图-控制器(MVC)架构,使得开发者可以将业务逻辑与表现层分离,提高代码的可维护性和可测试性。 3. **MyBatis**:MyBatis...
它允许开发者编写自定义的SQL,避免了过多的JDBC代码,使得数据库操作更为简便。MyBatis与Spring的集成使得事务管理变得更加轻松,同时也支持动态SQL,提高了查询的灵活性。 JavaWeb技术是构建Web应用程序的基础,...
2. **SpringMVC框架**:SpringMVC是Spring框架的一部分,专门用于处理Web应用程序的请求和响应。它将视图、控制器和模型分离开来,使得代码结构清晰,易于维护。用户请求被路由到适当的处理器,然后返回相应的视图...
根据给定的文件信息,我们可以提炼出一系列与Java程序设计相关的知识点,这48讲加上额外的2讲辅导课程,涵盖了Java编程的基础到高级技术,是深入理解和掌握Java语言的宝贵资源。以下是对这些知识点的详细说明: ###...