先上一段简单示例
kelas publik myTemplate {private DataSource DataSource; DataSource publik getDataSource () {return DataSource; } public void setDataSource (DataSource DataSource) {this.dataSource = DataSource; } public void Insert (String SQL) melempar sqlexception {connection conn = this.datasource.getConnection (); Pernyataan stmt = conn.createStatement (); stmt.executeUpdate (SQL); stmt.close (); conn.close (); }}Dao 类
Persondao kelas publik memperluas myTemplate {public void saveperson () melempar Exception {this.insert ("Insert Into Person (PID, PNAME) VALUES (3, 'AAA')"); }}musim semi 配置文件
<!-引入 Properti 配置文件-> <bean> <name properti = "lokasi"> <value> classpath: jdbc.properties </ value> </preate> </ bean> <bean id = "DataSource" dhash-method = "tutup"> <nama properti = "driverclassname" value = "$ {jdbc. value = "$ {jdbc.url}" /> <name properti = "username" value = "$ {jdbc.userName}" /> <name properti = "kata sandi" value = "$ {jdbc.password}" /> </tacter> <bean id = "mytemplate"> <! bean = "DataSource"/> </property> </ bean> <bean id = "persondao"> <name properti = "DataSource"> <Ref bean = "DataSource"/> </proper测试类
kelas publik persondaotest {@test public void testpersondao () melempar Exception {applicationContext context = new ClassPathXMLapPlicationContext ("cn/qjc/jdbc/applicationContext.xml"); Persondao persondao = (persondao) context.getbean ("persondao"); persondao.saveperson (); }}以上代码将 DataSource 注入给 MyTemplate , 再把 DataSource 注入给 persondao , 因为 persondao 继承 mytemplate , 所以拥有 DataSource 属性。既然 persondao 继承 mytemplate , 所以 persondao 类注入可以改为
<bean id = "persondao" parent = "mytemplate"> </t bean>
以上例子中 mytemplate 类似于设计模式中的模板模式也叫模板方法模式 , 模板方法模式是所有模式中最为常见的几个模式之一 , ,
模板模式 = 静态代码+动态变量
在 Musim semi 中动态变量可以用注入的形式给予。这样的编程方式适合包装成模板。静态代码构成了模板 , 而动态变量则是需要传入的参数。
Spring 与 JDBC 结合核心类 JDBCTEMPLATE
1 、基于模板的设置(为什么可以设置成基于模板的形式)
2 、完成了资源的创建和释放的工作
3 、简化为我们对 JDBC 的操作
4 、完成了对 JDBC 的核心流程的工作 , 包括 SQL 语句的创建和执行
5 、仅需要传递 DataSource 就可以把它实例化
6 、 Jdbctemplate 只需要创建一次
7 、 Jdbctemplate 是线程安全类
使用 Spring+jdbc 修改上面例子( mytemplate 类去掉)
Persondao kelas publik memperluas jdbcdaoSupport {public void saveperson (string sql) {this.getjdbctemplate (). execute (sql); }}musim semi 配置文件改为
<bean id = "persondao"> <name properti = "DataSource"> <Ref bean = "DataSource"/> </property> </tact>
Jdbctemplate 类结构图
执行过程
说明 :
1 、执行数据的操作的是 Jdbctemplate
2 、最根本的步骤就是要把 DataSource 注入到 Jdbctemplate
3 、通过给 JDBCtemplate 注入 DataSource
A 、采用构造器的形式注入
b 、采用 setter 方法进行注入
4 、可以给 JDBCDAOSUPPORT 注入 DATASOURCE
5 、可以给 JDBCDAOSUPPORT 注入 JDBCTEMPLATE
所以 Spring 与 jdbc 整合有三种方法 , 但实际上核心类为 jdbctemplate
1 、使用 Jdbctemplate
在 dao 类中 , 用 jdbctemplate 作为属性 , 用 spring 对 jdbctemplate 进行注入。再对 jdbctemplate 进行 DataSource 注入。
注 : 为什么只要对 Jdbctemplate 注入 DataSource 就可以了?
2 、继承 JDBCDAOSUPPORT
在 dao 类中 , 继承 jdbcdaosupport 。因为 jdbcdaosupport 已经有了 jdbctemplate 的引用 , 所以只要继承 所以只要继承 jdbcdaosupport 就相当于有了 jdbctemplate 属性。
3 、继承 Jdbctemplate
musim semi 还提供了其他 orm 框架整合模式都差不多 , 完全可直接套用。
Spring+Hibernate
Spring+JDo
由此可看出 Spring IOC 和 di 的强大 , ioc 和 di 完成了从接口到类的对应。利用 Spring 容器程序员很容易的在客户端实现面向接口编程 , 而且很容易给接口装配 , 结构也可以设置的很灵活。因为接口是自己写的 , 类也是自己写的 , 配置文件也是自己写的。 配置文件也是自己写的。 配置文件也是自己写的。 , , , ,
以上就是本文的全部内容 , 希望对大家的学习有所帮助 , 也希望大家多多支持武林网。