Spring集成持久层

spring对持久层提供了集成方案,包括对事务,jdbc等,还有MyBatis,MyBatis的集成由MyBatis自己提供

spring集成jdbc:

主要体现在JdbcTemplate类上面,spring自己提供的集成,是spring提供的对jdbc操作的便捷类。

提供了以DataSource(数据源)为构造参数的构造方法,使用步骤:

1.配置DataSource 因为不是自己写的所以要在配置类中引入,通过@Bean引入

2.定义Dao组件,Dao组件中定义JdbcTemplate属性,通过构造方法注入DataSource对象,创建JdbcTemplate,并赋值于jdbcTemplate属性。

3.定义业务组件,注入Dao组件

DataSource:

javax.sql.DataSource是Java提供的以连接池技术管理数据库连接的标准接口,具体实现由第三方提供,有C3P0,dbcp,proxool和druid

一. 导入必要的依赖

<dependencies>
        <!--spring上下文-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.3.13</version>
        </dependency>
        <!--spring对jdbc的集成-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.3.13</version>
        </dependency>
        <!--数据源-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.8</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.26</version>
        </dependency>
        <!--spring的测试方法-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>5.3.13</version>
        </dependency>
        <!--测试方法的具体依赖-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
        </dependency>
    </dependencies>

二. 开发配置类

import com.alibaba.druid.pool.DruidDataSource;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;


import javax.sql.DataSource;

@Configuration
@ComponentScan({"org.xupt.ygq.demo.dao","org.xupt.ygq.demo.service"})
//属性资源读取 ignoreResourceNotFound如果某个属性没找到忽略资源  不报错
@PropertySource(value = "classpath:application.properties",ignoreResourceNotFound = true)
public class MyConfig {
    //数据源需要的四个参数,我们从属性中进行加载,属性的值我们存放在资源文件中
    @Value("${spring.datasource.driver-class-name}")
    private String driverClassName;
    @Value("${spring.datasource.url}")
    private String url;
    @Value("${spring.datasource.username}")
    private String username;
    @Value("${spring.datasource.password}")
    private String password;
    //数据源是第三方写的所以我们只能在配置类里面配置,自己写的就可以用@Component注解放入容器中
    @Bean
    public DataSource druidDataSource(){
        //创建一个数据源
        DruidDataSource druidDataSource = new DruidDataSource();
        druidDataSource.setDriverClassName(driverClassName);
        druidDataSource.setUrl(url);
        druidDataSource.setUsername(username);
        druidDataSource.setPassword(password);
        return druidDataSource;
    }
}

 配置类总共四个注解:

①:@Configuration表示这是一个配置类

②:@ComponentScan表示这个配置类将要扫描的包,这里集成持久层,就去扫描持久底的包,最后还有引入业务组件

③:@PropertySource表示属性资源的读取,我们把对数据库操作需要的url等都定义在了资源文件夹下面,取值的时候需要在对应的属性上面加@Value通过${}赋值

④:@Bean表示这是受spring管理的一个bean,通过这样,把数据源引入spring容器中,以便注入到JdbcTemplate里面

三. 编写资源文件

 

 四. 开发Dao组件

 

import org.xupt.ygq.demo.dto.UserDto;
import org.xupt.ygq.demo.model.User;

import java.util.List;

public interface MyDao {
    public void createUserTable();

    public List<User> findUserList();

    public void insertOneUser(UserDto userDto);
}

主要来看Dao的实现类:

import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.stereotype.Repository;
import org.xupt.ygq.demo.dao.MyDao;
import org.xupt.ygq.demo.dto.UserDto;
import org.xupt.ygq.demo.model.User;

import javax.sql.DataSource;
import java.util.List;

@Repository//本注解专门用在持久化组件上,说明组件为受spring管理的数据访问对象
public class MyDaoImpl implements MyDao {
    //JdbcTemplate是spring提供的jdbc操作便捷类
    private JdbcTemplate jdbcTemplate;
    //数据源在这里由构造方法注入,不需要加注解,只要方法上有spring bean注解、@Component、@RestController、@Service
    public MyDaoImpl(DataSource ds) {
        this.jdbcTemplate = new JdbcTemplate(ds);//以数据源为构造参数的构造方法
    }

    public void createUserTable(){
        jdbcTemplate.execute("drop table if exists t_user");
        String sql =
                "create table t_user(u_id varchar(20) primary key,u_name varchar(20) not null,u_pwd varchar(20) not null)";
        jdbcTemplate.execute(sql);
        for (int i =1001;i<=1100;i++){
            jdbcTemplate.update
                    ("insert into t_user (u_id,u_name,u_pwd) values (?,?,?)",i,"用户"+i,"123456");
        }
    }

    @Override
    public List<User> findUserList() {
        //创建一个javabean与查询结果的映射器,负责将查询到的结果,封装到JavaBean中去 bean属性映射器,bean属性和行之间的映射
        RowMapper rowMapper = new BeanPropertyRowMapper(User.class);
        List<User> list = jdbcTemplate.query("select * from t_user",rowMapper);
        return list;
    }

    @Override
    public void insertOneUser(UserDto userDto) {
        jdbcTemplate.update("insert into t_user (u_id,u_name,u_pwd) values (?,?,?)",userDto.getU_id(),userDto.getU_name(),userDto.getU_pwd());
    }
}

一个注解:为什么只有一个注解,因为DataSource依赖构造方法注入不需要注解,只要保证类上面有注解表示这个类收spring容器管理即可

@Repository:本注解专门应用在持久化组件上面,说明组件为受spring管理的数据访问对象

一个属性:

JdbcTemplate:spring提供的对jdbc操作的便捷类,通过以DataSource为参数的构造方法创建,我们通过构造方法的方式对这个属性进行赋值,这样子可以不用注解

里面的方法自己结合后面的代码看吧:

public class UserDto {
    private String u_id;
    private String u_name;
    private String u_pwd;

    public String getU_id() {
        return u_id;
    }

    public void setU_id(String u_id) {
        this.u_id = u_id;
    }

    public String getU_name() {
        return u_name;
    }

    public void setU_name(String u_name) {
        this.u_name = u_name;
    }

    public String getU_pwd() {
        return u_pwd;
    }

    public void setU_pwd(String u_pwd) {
        this.u_pwd = u_pwd;
    }

    @Override
    public String toString() {
        return "User{" +
                "u_id='" + u_id + '\'' +
                ", u_name='" + u_name + '\'' +
                '}';
    }
}
public class User {
    private String u_id;
    private String u_name;

    public String getU_id() {
        return u_id;
    }

    public void setU_id(String u_id) {
        this.u_id = u_id;
    }

    public String getU_name() {
        return u_name;
    }

    public void setU_name(String u_name) {
        this.u_name = u_name;
    }

    @Override
    public String toString() {
        return "User{" +
                "u_id='" + u_id + '\'' +
                ", u_name='" + u_name + '\'' +
                '}';
    }
}

测试方法:

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringRunner;
import org.xupt.ygq.demo.config.MyConfig;
import org.xupt.ygq.demo.dao.MyDao;
import org.xupt.ygq.demo.dto.UserDto;
import org.xupt.ygq.demo.model.User;
import org.xupt.ygq.demo.service.MyService;

import javax.sql.DataSource;
import java.util.List;

@RunWith(SpringRunner.class)
@ContextConfiguration(classes = MyConfig.class)
public class MyTest {
    @Autowired
    private DataSource ds;
    @Test
    public void test1(){
        System.out.println(ds);
    }
    @Autowired
    private MyDao myDao;
    @Test
    public void testDaoCreateUserTable(){
        myDao.createUserTable();
    }
    @Test
    public void testDaoFindUserList(){
        List<User> list = myDao.findUserList();
        list.stream().forEach(user-> System.out.println(user));
    }
    @Test
    public void testDaoInsertOneUser(){
        UserDto userDto = new UserDto();
        userDto.setU_id("A001");
        userDto.setU_name("人");
        userDto.setU_pwd("00000");
        myDao.insertOneUser(userDto);
    }
    @Autowired
    private MyService myService;
    @Test
    public void testFnOfMyService(){
        myService.fn();
    }
}

五. 业务组件的开发

 

public interface MyService {
    public void fn();
}
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.xupt.ygq.demo.dao.MyDao;
import org.xupt.ygq.demo.dto.UserDto;
import org.xupt.ygq.demo.service.MyService;
@Service
public class MyServiceImpl implements MyService {
    @Autowired
    private MyDao myDao;

    @Override
    public void fn() {
        UserDto userDto = new UserDto();
        userDto.setU_id("A002");
        userDto.setU_name("人2");
        userDto.setU_pwd("000002");
        myDao.insertOneUser(userDto);
    }
}

业务组件依靠Dao里面的方法,所以要把Dao注入进来,测试方法在上面。

最后包结构展示:

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值