JDBC+Spring学习

JDBC

JDBC(Java Data Base Connectivity)

1.what?

一种Java API,为多种数据库提供统一访问。

2.why?

如果没有JDBC接口,数据库版本不统一,需要使用Oracle数据库的时候,程序员要了解Oracle数据库驱动API,需要连接其他数据库的时候,程序员又要学习另一种API。JDBC是一个统一规范接口,各个数据库生产商提供接口的实现。

3.how?

加载驱动
Driver接口由数据库生产商提供。在编程中要连接数据库,必须先装载特定厂商的数据库驱动程序,不同的数据库有不同的装载方法。如:
装载MySql驱动 Class.forName(“com.mysql.jdbc.Driver”);

获得连接
Connection与特定数据库的连接(会话),在连接上下文中执行sql语句并返回结果。DriverManager.getConnection(url, user, password)方法建立在JDBC URL中定义的数据库Connection连接上。
连接MySql数据库:Connection conn = DriverManager.getConnection(“jdbc:mysql://host:port/database”, “user”, “password”);

基本操作
用于执行静态SQL语句并返回它所生成结果的对象。

三种Statement类:
· Statement:由createStatement创建,用于发送简单的SQL语句(不带参数)。
· PreparedStatement :继承自Statement接口,由preparedStatement创建,用于发送含有一个或多个参数的SQL语句。PreparedStatement对象比Statement对象的效率更高,并且可以防止SQL注入,所以我们一般都使用PreparedStatement。
· CallableStatement:继承自PreparedStatement接口,由方法prepareCall创建,用于调用存储过程。

常用Statement方法:
· execute(String sql):运行语句,返回是否有结果集
· executeQuery(String sql):运行select语句,返回ResultSet结果集。
· executeUpdate(String sql):运行insert/update/delete操作,返回更新的行数。
· addBatch(String sql) :把多条sql语句放到一个批处理中。
· executeBatch():向数据库发送一批sql语句执行。

ResultSet接口
· ResultSet提供检索不同类型字段的方法,常用的有:
· getString(int index)、getString(String columnName):获得在数据库里是varchar、char等类型的数据对象。
· getFloat(int index)、getFloat(String columnName):获得在数据库里是Float类型的数据对象。
· getDate(int index)、getDate(String columnName):获得在数据库里是Date类型的数据。
· getBoolean(int index)、getBoolean(String columnName):获得在数据库里是Boolean类型的数据。
· getObject(int index)、getObject(String columnName):获取在数据库里任意类型的数据。

ResultSet还提供了对结果集进行滚动的方法:
· next():移动到下一行
· Previous():移动到前一行
· absolute(int row):移动到指定行
· beforeFirst():移动resultSet的最前面。
· afterLast() :移动到resultSet的最后面。

释放资源
使用后依次关闭对象及连接:ResultSet → Statement → Connection

总结步骤
1、把驱动拷贝进项目下的lib文件夹
2、加载数据库驱动
class.forName(‘com.mysql.jdbc.Driver’);
2、建立数据库连接
url的格式
jdbc:mysql://localhost:3306/【database】
协议:子协议://目标IP地址:端口/数据库
建立连接语句
Connection connection = DriverManager.getConnection(
“jdbc:mysql://localhost:3306/【database】”, “【username】”,"【password】");
4、执行查询语句
5、释放资源,断开连接

Spring

名词介绍

Spring 框架是一个分层架构,由 7 个定义良好的模块组成。

核心容器:核心容器提供 Spring 框架的基本功能。核心容器的主要组件是 BeanFactory,它是工厂模式的实现。BeanFactory 使用控制反转 (IOC) 模式将应用程序的配置和依赖性规范与实际的应用程序代码分开。
Spring 上下文:Spring 上下文是一个配置文件,向 Spring 框架提供上下文信息。Spring 上下文包括企业服务,例如 JNDI、EJB、电子邮件、国际化、校验和调度功能。
Spring AOP:通过配置管理特性,Spring AOP 模块直接将面向方面的编程功能集成到了 Spring 框架中。所以,可以很容易地使 Spring 框架管理的任何对象支持 AOP。Spring AOP 模块为基于 Spring 的应用程序中的对象提供了事务管理服务。通过使用 Spring AOP,不用依赖 EJB 组件,就可以将声明性事务管理集成到应用程序中。
Spring DAO:JDBC DAO 抽象层提供了有意义的异常层次结构,可用该结构来管理异常处理和不同数据库供应商抛出的错误消息。异常层次结构简化了错误处理,并且极大地降低了需要编写的异常代码数量(例如打开和关闭连接)。Spring DAO 的面向 JDBC 的异常遵从通用的 DAO 异常层次结构。
Spring ORM:Spring 框架插入了若干个 ORM 框架,从而提供了 ORM 的对象关系工具,其中包括 JDO、Hibernate 和 iBatis SQL Map。所有这些都遵从 Spring 的通用事务和 DAO 异常层次结构。
Spring Web 模块:Web 上下文模块建立在应用程序上下文模块之上,为基于 Web 的应用程序提供了上下文。所以,Spring 框架支持与 Jakarta Struts 的集成。Web 模块还简化了处理多部分请求以及将请求参数绑定到域对象的工作。
Spring MVC 框架:MVC 框架是一个全功能的构建 Web 应用程序的 MVC 实现。通过策略接口,MVC 框架变成为高度可配置的,MVC 容纳了大量视图技术,其中包括 JSP、Velocity、Tiles、iText 和 POI。

依赖注入(Dependency Injection) == 控制反转(Inversion of Conctrol)
当某个java实例(调用者)需要调用另一个java实例(被调用者)时,传统情况下,通过调用者来创建被调用者的实例,通常通过new来创建;
而在依赖注入的模式下创建被调用者的工作不再由调用者来完成,因此称之为"控制反转";创建被调用者实例的工作通常由Spring来完成,然后注入调用者,所以也称之为"依赖注入"。

参考:
https://www.cnblogs.com/erbing/p/5805727.html

猜你喜欢

转载自blog.csdn.net/yuan_exc/article/details/93891488