Spring模块对象:

把共性的方法抽取出来固定为一个模板,后续再操作只需要填充内容即可。
比如:淘宝每次买东西都要填写地址,只是每次买的东西不一样,所以可以做一个默认地址,每次买东西都要去选商品就行了,不需要每次都填写地址。

JdbcTemplate

pom.xml

    <dependencies><!--无mybatis配置坐标--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.47</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.1.9.RELEASE</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.1.9.RELEASE</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.16</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>5.1.9.RELEASE</version></dependency></dependencies>

工具类JDBCConfig

public class JDBCConfig {@Value("${jdbc.driver}")private String driver;@Value("${jdbc.url}")private String url;@Value("${jdbc.username}")private String userName;@Value("${jdbc.password}")private String password;@Bean("dataSource")public DataSource getDataSource(){DruidDataSource ds = new DruidDataSource();ds.setDriverClassName(driver);ds.setUrl(url);ds.setUsername(userName);ds.setPassword(password);return ds;}//注册JdbcTemplate模块对象bean@Bean("jdbcTemplate")public JdbcTemplate getJdbcTemplate(@Autowired DataSource dataSource){return new JdbcTemplate(dataSource);}@Bean("jdbcTemplate2")public NamedParameterJdbcTemplate getJdbcTemplate2(@Autowired DataSource dataSource){return new NamedParameterJdbcTemplate(dataSource);}
}

工具类SpringConfig

@Configuration
@ComponentScan("com.itheima")
@PropertySource("classpath:jdbc.properties")
@Import(JDBCConfig.class)
public class SpringConfig {}

AccountDao

public interface AccountDao {void save(Account account);void delete(Integer id);void update(Account account);String findNameById(Integer id);Account findById(Integer id);List<Account> findAll();List<Account> findAll(int pageNum,int preNum);Long getCount();
}

实现类AccountDaoImpl:(提供标准的sql语句操作API)

//dao注册为bean
@Repository("accountDao")
public class AccountDaoImpl implements AccountDao {//注入模板对象@Autowiredprivate JdbcTemplate jdbcTemplate;public void save(Account account) {String sql = "insert into account(name,money)values(?,?)";jdbcTemplate.update(sql,account.getName(),account.getMoney());}public void delete(Integer id) {String sql = "delete from account where id = ?";jdbcTemplate.update(sql,id);}public void update(Account account) {String sql = "update account set name = ? , money = ? where id = ?";jdbcTemplate.update(sql, account.getName(),account.getMoney(),account.getId());}public String findNameById(Integer id) {String sql = "select name from account where id = ? ";//单字段查询可以使用专用的查询方法,必须制定查询出的数据类型,例如name为String类型return jdbcTemplate.queryForObject(sql,String.class,id );}public Account findById(Integer id) {String sql = "select * from account where id = ? ";//支持自定义行映射解析器RowMapper<Account> rm = new RowMapper<Account>() {public Account mapRow(ResultSet rs, int rowNum) throws SQLException {Account account = new Account();account.setId(rs.getInt("id"));account.setName(rs.getString("name"));account.setMoney(rs.getDouble("money"));return account;}};return jdbcTemplate.queryForObject(sql,rm,id);}public List<Account> findAll() {String sql = "select * from account";//使用spring自带的行映射解析器,要求必须是标准封装return jdbcTemplate.query(sql,new BeanPropertyRowMapper<Account>(Account.class));}public List<Account> findAll(int pageNum, int preNum) {String sql = "select * from account limit ?,?";//分页数据通过查询参数赋值return jdbcTemplate.query(sql,new BeanPropertyRowMapper<Account>(Account.class),(pageNum-1)*preNum,preNum);}public Long getCount() {String sql = "select count(id) from account ";//单字段查询可以使用专用的查询方法,必须制定查询出的数据类型,例如数据总量为Long类型return jdbcTemplate.queryForObject(sql,Long.class);}
}

实现类AccountDaoImpl2:

//dao注册为bean
@Repository
//@Primary
public class AccountDaoImpl2 implements AccountDao {//注入模板对象@Autowiredprivate NamedParameterJdbcTemplate jdbcTemplate;public void save(Account account) {String sql = "insert into account(name,money)values(:name,:money)";Map pm = new HashMap();pm.put("name",account.getName());pm.put("money",account.getMoney());jdbcTemplate.update(sql,pm);}public void delete(Integer id) {}public void update(Account account) {}public String findNameById(Integer id) {return null;}public Account findById(Integer id) {return null;}public List<Account> findAll() {return null;}public List<Account> findAll(int pageNum, int preNum) {return null;}public Long getCount() {return null;}
}

实体类Account

public class Account implements Serializable {private Integer id;private String name;private Double money;
}

AccountService

public interface AccountService {void save(Account account);void delete(Integer id);void update(Account account);String findNameById(Integer id);Account findById(Integer id);List<Account> findAll();List<Account> findAll(int pageNum,int preNum);Long getCount();
}

AccountServiceImpl

@Service("accountService")
public class AccountServiceImpl implements AccountService {@Autowiredprivate AccountDao accountDao;public void save(Account account) {accountDao.save(account);}public void delete(Integer id) {accountDao.delete(id);}public void update(Account account){accountDao.update(account);}public String findNameById(Integer id) {return accountDao.findNameById(id);}public Account findById(Integer id) {return accountDao.findById(id);}public List<Account> findAll() {return accountDao.findAll();}public List<Account> findAll(int pageNum, int preNum) {return accountDao.findAll(pageNum,preNum);}public Long getCount() {return accountDao.getCount();}
}

pom.xml

   <dependencies><!--无mybatis配置坐标--><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.1.9.RELEASE</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>5.1.9.RELEASE</version></dependency><dependency><groupId>org.springframework.data</groupId><artifactId>spring-data-redis</artifactId><version>2.0.6.RELEASE</version></dependency><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.9.0</version></dependency></dependencies>

RedisTemplate

RedisTemplate对象结构

public void changeMoney(Integer id, Double money) {redisTemplate.opsForValue().set("account:id:"+id,money);
}
public Double findMondyById(Integer id) {Object money = redisTemplate.opsForValue().get("account:id:" + id);return new Double(money.toString());
}

策略模式应用:

策略模式(Strategy Pattern)使用不同策略的对象实现不同的行为方式,策略对象的变化导致行为的变化。

Spring模板对象相关推荐

  1. Spring模板对象之RedisTemplate(Spring整合jedis)

    Spring模板对象之RedisTemplate 构建maven项目 pom <?xml version="1.0" encoding="UTF-8"?& ...

  2. 【Spring实战】注入非Spring Bean对象

    2019独角兽企业重金招聘Python工程师标准>>> 大家经常用到Spring IOC去管理对象之间的依赖关系,但一般情况下都有一个前提:这些Bean对象必须是通过Spring容器 ...

  3. spring工厂生产对象时对象生命周期的三个阶段

    spring生产对象的生命周期包括创建.初始化.销毁. 一.创建 spring创建bean是何时创建的? 如果该bean是单例的,那么和工厂applicationContext的创建一起被创建:如果该 ...

  4. 根据Spring上下文对象xxxContext获得*.properties属性文件中的配置属性值

    最近写了一个文件上传和下载的简单测试demo,对于这种需要部署在服务器上的,而不是随便在本机上跑跑的那种,对于上传和下载的目录路径的选择和配置尤为重要,这个不能在代码里面写死,必须是灵活可配置的. 一 ...

  5. 条形码设计软件BarTender实用教程——模板对象常见问题解答

    BarTender是一款优秀的标签.条形码.卡片以及RFID标签设计和打印软件.所有版本的BarTender都具有独立的设计和打印功能,对于更高级的用户,自动化版和企业自动化版本提供了更强大的集成功能 ...

  6. C++ 类模板对象传参方式

    #include <iostream> #include <string> using namespace std;/***************************** ...

  7. C++模板学习02(类模板)(类模板语法、类模板与函数模板的区别、类模板中的成员函数创建时机、类模板对象做函数参数、类模板与继承、类模板成员函数类外实现、类模板分文件编写、类模板与友元)

    C++引用详情(引用的基本语法,注意事项,做函数的参数以及引用的本质,常量引用) 函数高级C++(函数的默认参数,函数的占位参数,函数重载的基本语法以及注意事项) C++类和对象-封装(属性和行为作为 ...

  8. spring 事务 对象保存之后,修改的时候,自动更新提交?

    2019独角兽企业重金招聘Python工程师标准>>> 这段时间遇到一个 很奇怪的问题.而这个问题,其实一直都困扰着我,只是以前没有怎么去分析,以为是其他问题引起的.可是 这块代码重 ...

  9. Filter获取Spring Bean对象

    Filter拦截器获取Bean SSM框架中,Bean都是被Spring容器管理的,使用的时候,直接通过注解@Autowired,注入即可 在Filter中,不能使用@Autowired注解注入,通过 ...

最新文章

  1. java环境变量设置
  2. beanstalkd 协议中文版
  3. string操作小汇总
  4. ES6 使用数据类型Set求交集、并集、差集
  5. mysql004子查询.相关子查询.不相关子查询
  6. 机械制图中外螺纹的画法_机械制图基础常识42条,条条都是经典!
  7. linux系统管理:认识安装linux(一)
  8. 使用VLC Media Player 在Mac上修剪视频
  9. matlab实现将彩色图像(R,G,B)色分量的直方图匹配,并计算其相关性
  10. navicat如何创建数据库及如何导入数据库文件【初学者适用】
  11. matlab GUI页面 科学计算器代码
  12. 80端口和443端口的作用
  13. 软件调试方法及调试原则
  14. 服务器防护是什么?为什么需要防护?
  15. 手机html像素,手机分辨率和网页中的PX是一回事吗?
  16. 摄影测量之空间后方交会程序
  17. EINT、DINT、ERTM、DRTM和EALLOW、EDIS、ESTOP0解析
  18. 关于iconfont字体图标在IE上无法显示的问题
  19. JavaScript 实例:点击漫天小星星 (获取整个浏览器窗口的宽高)
  20. Ant Design Charts绘制中国地图并动态添加标记点

热门文章

  1. html中form标签的作用style,HTML5中meta常用标签属性说明
  2. 饥荒联机版连不上服务器_饥荒联机版无法连接klei服务器及刷不出服务器解决方法一览...
  3. php 错误 异常,php中的异常和错误解析
  4. 2014北科计算机原理试题答案,北科_计算机组成原理考题-A卷答案
  5. android 中自定义键盘,【图片】自定义属于自己的专属键盘的思路!!!(需要有android编程基础)【exagear吧】_百度贴吧...
  6. matlab设置工作路径
  7. 机器学习入门(1)之基本概念简介
  8. mysql or走索引吗_加了索引,mysql查询就一定会用吗?
  9. java 访问路径_java获取项目访问路径的相关方法
  10. python微信聊天机器人源码_8.【代码】微信聊天机器人(API的应用) - Python网络爬虫实战...