Spring的jdbcTemplate操作

1 spring框架一站式框架

1)针对javaee三层,每一层都有解决技术

2)在dao层,使用 jdbcTemplate

 

2 spring对不同的持久化层技术都进行封装

 

1jdbcTemplatejdbc进行封装

 

3 jdbcTemplate使用和dbutils使用很相似,都数据库进行crud操作

删改:

1.导入jdbcTemplate的jar
<!--  数据库驱动jar包-->
<dependency>
    <groupId>mysql</groupId>
	<artifactId>mysql-connector-java</artifactId>
  <version>5.1.26</version>
 </dependency>
<dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>4.3.12.RELEASE</version>
 </dependency>



:不要忘了数据库驱动jar

2.创建对象,设置数据库信息
//properties文件(或Oracle的)
url=jdbc:mysql://localhost:3306/news
driverClass=com.mysql.jdbc.Driver
userName1=root
password=123
//Java类
public class MyConf {
	@Value("${url}")
	private String url;
	@Value("${driverClass}")
	private String driverClassName;
	@Value("${userName1}")
	private String username;
	@Value("${password}")
	private String password;
	@Bean
	public JdbcTemplate jdbcTemplate(DataSource dataSource){
		return new JdbcTemplate(dataSource);
	}
	@Bean
	public DataSource dataSource(){
		DriverManagerDataSource dmds=new DriverManagerDataSource();
		dmds.setUrl(url);
		dmds.setDriverClassName(driverClassName);
		dmds.setUsername(username);
		dmds.setPassword(password);
		return dmds;
	}
}
//spring配置文件中写
<context:property-placeholder location="classpath:jdbcmysql.properties" />
3 创建jdbcTemplate对象,设置数据源
JdbcTemplate jdbc=new JdbcTemplate(dataSource);
或自动装配:
@Autowired
private JdbcTemplate jdbc;
4 调用jdbcTemplate对象里面的方法实现操作
String sql="insert into mynews (title,content,htmlpath,createtime) values ('"+title+"','"+content+"','','"+createTime+"')";
		jdbc.execute(sql);

查询:

 dbutils时候,有接口 ResultSetHandler

 dbutils提供了针对不同的结果实现类

 jdbcTemplate实现查询,有接口 RowMapper

 jdbcTemplate针对这个接口没有提供实现类,得到不同的类型数据需要自己进行数据 封装

返回对象集合:


public List<News> queryAll() {
		String sql="select newid,title,content,createtime from mynews";
		 return jdbc.query(sql,new BeanPropertyRowMapper<News>(News.class));
	}
或query(sql,new BeanHandler<User>(User.class))

返回list<Map>

String sql="select count(*) as rw from mynews where content like'%"+name+"%'";
		List<Map<String, Object>> res=jdbc.queryForList(sql);
或query(sql,new BeanListHander<User>(User.class))

查询某一个返回值:

方法1
String sql="select count(*) as rw from mynews where content like'%"+name+"%'";
		List<Map<String, Object>> res=jdbc.queryForList(sql);
		Integer count=Integer.parseInt(res.get(0).get("RW").toString());
方法2:
Int count=jdbcTemplate queryForObject(sql,Integer.class);




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值