利用spring整合mybatis事务管理

i:修改spring.xml—加载数据库连接信息的属性文件
加载上方的jabc-config.properties数据库连接的基础信息
ii:配置Druid数据源的Bean
利用阿里巴巴的数据库连接池,根据上方的jabc-config.properties的文件创建一个dataSource连接信息
iii:配置SqlSessionFactory的Bean,并注入DataSource
把数据库连接存放在工厂中
iiii:配置自动扫描mapper的Bean—MapperScannerConfigurer
把上方的mapper接口文件都自动注入到IoC容器中,实现类Bean的名称默认为接口类名的首字母小写

二.@Transactional 注解

@Transactional 实质是使用了 JDBC 的事务来进行事务控制的
@Transactional 基于 Spring 的动态代理的机制

三.代码

1.controller层

@Controller
public class StudentController {
 
    @Autowired
    StudentService ss;
 
 
    public String query(){
        List<Student> list = ss.query();
        System.out.println(list);
        return null;
    }
 
    public String add(Student student){
        ss.add(student);
        return null;
    }
 
    //public void update(Student student);
 
    public String update(Student student){
        ss.update(student);
        return null;
    }
 
    //public Student queryById(Integer id);
    public Student queryById(Integer id){
        Student student = ss.queryById(id);
        System.out.println(student);
        return student;
    }
 
    //public void delete(Integer id);
    public void delete (Integer id){
         ss.delete(id);
 
    }
2.dao层

public interface StudentDao {
    public List<Student> query();
 
    void add(Student student);
 
    public void update(Student student);
 
    public Student queryById(Integer id);
 
    public void delete(Integer id);
3.entity层

 @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", email='" + email + '\'' +
                ", age=" + age +
                '}';
    }
 
    public Integer getId() {
        return id;
    }
 
    public void setId(Integer id) {
        this.id = id;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    public String getEmail() {
        return email;
    }
 
    public void setEmail(String email) {
        this.email = email;
    }
 
    public Integer getAge() {
        return age;
    }
 
    public void setAge(Integer age) {
        this.age = age;
    }
}
4.service层

public interface StudentService {
    List<Student> query();
 
    void add(Student student);
 
    void update(Student student);
 
    Student queryById(Integer id);
 
    void delete(Integer id);
}
5.serviceimpl层

@Service
public class StudentServiceImpl implements StudentService {
 
    @Autowired
    StudentDao dao;
 
    @Override
    public List<Student> query() {
        List<Student> list = dao.query();
        return list;
    }
 
    @Override
    public void add(Student student) {
        dao.add(student);
    }
 
    @Override
    public void update(Student student) {
        dao.update(student);
    }
 
    @Override
    public Student queryById(Integer id) {
        Student Byid = dao.queryById(id);
        return Byid;
    }
 
    @Override
    public void delete(Integer id) {
        dao.delete(id);
    }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值