1 spring框架一站式框架
(1)针对javaee三层,每一层都有解决技术
(2)在dao层,使用 jdbcTemplate
2 spring对不同的持久化层技术都进行封装
(1)jdbcTemplate对jdbc进行封装
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);