JavaWeb 学习笔记 spring+jdbc整合开发初步

2024-06-24 10:32

本文主要是介绍JavaWeb 学习笔记 spring+jdbc整合开发初步,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JdbcTemplate类是Spring的核心类之一,可以在org.springframework.jdbc.core中找到它。JdbcTemplate类在内部已经处理数据库的建立和释放,可以避免一些常见的错误。

JdbcTemplate类可直接通过数据源的应用实例化,然后在服务中使用,也可在xml配置中作为JavaBean应用给服务使用

直接上一个实例

步骤1.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="org.gjt.mm.mysql.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/springtest?useUnicode=true&characterEncoding=UTF8"/>
<property name="username" value="root"/>
<property name="password" value=""/>
<!-- 连接池启动时的初始值 -->
<property name="initialSize" value="1"/>
<!-- 连接池的最大值 -->
<property name="maxActive" value="500"/>
<!-- 最大空闲值,当经过一个高峰时间后,连接池可以慢慢释放用不到的连接,直到maxidle为止-->
<property name="maxIdle" value="2"/>
<!-- 最小空闲值,当连接池的剩余小于阀值时,连接池会自动生气个链接-->
<property name="minIdle" value="1"/>
</bean>
<bean id="userService" class="edu.gzu.springJDBC.impl.UserServiceImp">
<property name="dataSource" ref="dataSource"></property>
</bean>
</beans>


步骤2.建立与数据库对象对应的对象

package edu.gzu.springJDBC.bean;
public class User {
private int id;
private String name;
private String phonenum;
public User(int id, String name, String phonenum) {
super();
this.id = id;
this.name = name;
this.phonenum = phonenum;
}
//...省去相应需要的参数构造方法
//...省去setter和getter方法
}


步骤3.由于spring AOP面向接口编程,建立相应的接口类

package edu.gzu.springJDBC;
import java.util.List;
import edu.gzu.springJDBC.bean.User;
public interface userBeanService {
/**
* 存储用户信息对象
* @param user
*/
public void save(User user);
/**
* 修改用户信息对抽象
* @param user
*/
public void update(User user);
/**
* 根据id删除用户信息对象
* @param id
*/
public void delete(int id);
/**
* 根据id获取相应的用户信息
* @param id
* @return
*/
public User getUserById(int id);
/**
* 获取数据库中全部的用户信息对象
* @return
*/
public List<User> getAllUser();
}


步骤4.编写实现接口的具体方法

package edu.gzu.springJDBC.impl;
import java.util.List;
import javax.sql.DataSource;
import org.springframework.jdbc.core.JdbcTemplate;
import edu.gzu.springJDBC.userBeanService;
import edu.gzu.springJDBC.bean.User;
public class UserServiceImp implements userBeanService {
private DataSource dataSource;
private JdbcTemplate jdbcTemplate;
public void setDataSource(DataSource dataSource) {
this.dataSource = dataSource;
this.jdbcTemplate=new JdbcTemplate(dataSource);
}
@Override
public void delete(int id) {
jdbcTemplate.update("delete from user where id=?", new Object[]{id}, 
new int[]{java.sql.Types.INTEGER});
System.out.print("用户信息删除成功!");
}
@Override
public List<User> getAllUser() {
List<User> users=(List) jdbcTemplate.query("select * from user", new NewRowMapper());
return users;
}
@Override
public User getUserById(int id) {
List<User> users=(List) jdbcTemplate.query("select * from user where id=?",
new Object[]{id}, new NewRowMapper());
return users.get(0);
}
@Override
public void save(User user) {
jdbcTemplate.update("insert into user (name,phonenum) values (?,?)", 
new String[]{user.getName(),user.getPhonenum()}, 
new int[]{java.sql.Types.VARCHAR,java.sql.Types.VARCHAR});
System.out.print("用户信息保存成功!");
}
@Override
public void update(User user) {
jdbcTemplate.update("update user set name=?,phonenum=? where id=?", 
new Object[]{user.getName(),user.getPhonenum(),user.getId()},
new int[]{java.sql.Types.VARCHAR,java.sql.Types.VARCHAR,java.sql.Types.INTEGER});
System.out.print("用户信息更新成功!");
}
}
//附:数据库查询条件返回的结果集匹配方法
package edu.gzu.springJDBC.impl;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.springframework.jdbc.core.RowMapper;
import edu.gzu.springJDBC.bean.User;
public class NewRowMapper implements RowMapper {
@Override
public Object mapRow(ResultSet rs, int index) throws SQLException {
User user=new User(rs.getString("name"));
user.setId(rs.getShort("id"));
user.setPhonenum(rs.getString("phonenum"));
return user;
}
}



步骤5.编写测试方法,测试接口类

package edu.gzu.springJDBC.Test;
import java.util.List;
import java.util.Random;
import org.junit.BeforeClass;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import edu.gzu.springJDBC.userBeanService;
import edu.gzu.springJDBC.bean.User;
import edu.gzu.springJDBC.impl.UserServiceImp;
public class UserTest {
private static userBeanService user;
@BeforeClass
public static void setUpBeforeClass() throws Exception {
try {
ApplicationContext act=new ClassPathXmlApplicationContext("applicationContext.xml");
user=(userBeanService) act.getBean("userService");
} catch (Exception e) {
e.printStackTrace();
}
}
@Test public void deleteTest(){
user.delete(7);
}
@Test public void updateTest(){
User user4=new User(6,"朱元璋","13894349843");
user.update(user4);
}
@Test public void findAllTest(){
List<User> user3=user.getAllUser();
for(User user:user3){
System.out.println("id:"+user.getId()+"  用户名:"+user.getName()+"    电话号码:"+user.getPhonenum());
}
}
@Test public void saveTest(){
Random rand=new Random();
for(int i=0;i<6;i++){
user.save(new User("贾"+i+"春","1568745"+(rand.nextInt(1000)+1000)));
}
}
@Test public void findTest(){
User user2=user.getUserById(2);
System.out.println("用户名:"+user2.getName()+"    电话号码:"+user2.getPhonenum());
}
}


附:需要导入的jar包

F:\开发库\commons\commons-logging-1.1.3.jar
F:\开发库\commons\commons-pool.jar
F:\开发库\commons\commons-dbcp-1.2.2-src\commons-dbcp-1.2.2.jar
F:\开发库\spring-framework-2.5.6\常用\spring.jar
F:\开发库\spring-framework-2.5.6\常用\spring-aop.jar
F:\开发库\spring-framework-2.5.6\常用\spring-context.jar
F:\开发库\spring-framework-2.5.6\常用\spring-core.jar
F:\开发库\spring-framework-2.5.6\常用\spring-jdbc.jar
F:\开发库\spring-framework-2.5.6\常用\spring-orm.jar
F:\开发库\spring-framework-2.5.6\常用\spring-web.jar
F:\开发库\spring-framework-2.5.6\常用\spring-webmvc.jar
F:\开发库\mysql-connector-java-5.1.18\mysql-connector-java-5.1.18-bin.jar
F:\开发库\spring-framework-2.5.6\spring-tx.jar

 

这篇关于JavaWeb 学习笔记 spring+jdbc整合开发初步的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1089899

相关文章

51单片机学习记录———定时器

文章目录 前言一、定时器介绍二、STC89C52定时器资源三、定时器框图四、定时器模式五、定时器相关寄存器六、定时器练习 前言 一个学习嵌入式的小白~ 有问题评论区或私信指出~ 提示:以下是本篇文章正文内容,下面案例可供参考 一、定时器介绍 定时器介绍:51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 定时器作用: 1.用于计数系统,可

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

Java五子棋之坐标校正

上篇针对了Java项目中的解构思维,在这篇内容中我们不妨从整体项目中拆解拿出一个非常重要的五子棋逻辑实现:坐标校正,我们如何使漫无目的鼠标点击变得有序化和可控化呢? 目录 一、从鼠标监听到获取坐标 1.MouseListener和MouseAdapter 2.mousePressed方法 二、坐标校正的具体实现方法 1.关于fillOval方法 2.坐标获取 3.坐标转换 4.坐

Spring Cloud:构建分布式系统的利器

引言 在当今的云计算和微服务架构时代,构建高效、可靠的分布式系统成为软件开发的重要任务。Spring Cloud 提供了一套完整的解决方案,帮助开发者快速构建分布式系统中的一些常见模式(例如配置管理、服务发现、断路器等)。本文将探讨 Spring Cloud 的定义、核心组件、应用场景以及未来的发展趋势。 什么是 Spring Cloud Spring Cloud 是一个基于 Spring

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

java8的新特性之一(Java Lambda表达式)

1:Java8的新特性 Lambda 表达式: 允许以更简洁的方式表示匿名函数(或称为闭包)。可以将Lambda表达式作为参数传递给方法或赋值给函数式接口类型的变量。 Stream API: 提供了一种处理集合数据的流式处理方式,支持函数式编程风格。 允许以声明性方式处理数据集合(如List、Set等)。提供了一系列操作,如map、filter、reduce等,以支持复杂的查询和转

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备