SpringBoot中业务层标准开发和快速开发(大全)

  可以对照数据层开发学习:

http://t.csdn.cn/dE36W

一、业务层标准开发

首先要说明一下,Service层接口定义和数据层接口定义有较大的区别

selectByUserNameAndPassword(String username, String password);

上面这一条语句着重于数据,一目了然,是数据的

login(String username,String password);

上面这条语句着重于功能,能让人一眼看清功能是什么

①接口:在这里定义方法

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.company.domain.Book;

import java.util.List;

public interface BookService {
    Boolean save(Book book);
    Boolean update(Book book);
    Boolean delete(Integer id);
    Book getById(Integer id);
    List<Book> getAll();
//     当前页码值,  每页显示数
    IPage<Book> getPage(int currentPage, int pageSize);
}

     通过这个实现数据库的操作  里面有数据库中各种各样的操作 

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.company.domain.Book;
import org.apache.ibatis.annotations.Mapper;

@Mapper //通过这个实现数据库的操作  里面有数据库中各种各样的操作
public interface BookDao  extends BaseMapper<Book> {//指定泛型才能知道操作谁

}

②实体类:

//@Getter所有的get方法
//@Setter所有的set方法
//@NoArgsConstructor 无参构造
//@AllArgsConstructor//全部的构造

@Data  //get+set+toString+hashcode+equals  但是没有构造方法
@TableName(value = "t_book")
public class Book {
    //    这里的属性名 要和数据库表中的属性名一致,要不然最终的查询结果是null
//    将数据库中的结果对此变量名进行注入
    @TableId(value="id",type = IdType.AUTO)  //代表自增算法
    @TableField(value = "id")
    private int id;
    @TableField(value = "bookName")
    private String bookName;
    @TableField(value = "statue")
    private String statue;

}

③service层:  对接口中的方法进行调用

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.company.dao.BookDao;
import com.company.domain.Book;
import com.company.service.BookService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Service   //业务层开发注解  定义成业务层对应的bean
public class BookServiceImpl implements BookService {
    @Autowired
    private BookDao bookDao;

    @Override
    public Boolean save(Book book) {
        //bookDao.insert(book)返回的是影响的行计数  我们让他>0,就说明有影响的数据,就返回true
        return bookDao.insert(book) >0;
    }

    @Override
    public Boolean update(Book book) {
        return bookDao.updateById(book) >0;
    }

    @Override
    public Boolean delete(Integer id) {
        return bookDao.deleteById(id) >0;
    }

    @Override
    public Book getById(Integer id) {
        return bookDao.selectById(id);
    }

    @Override
    public List<Book> getAll() {
        return bookDao.selectList(null);// null说明查询的时候没有条件,那这就是 查询全部数据
    }

    @Override //分页操作
    public IPage<Book> getPage(int currentPage, int pageSize) {
        IPage iPage = new Page(currentPage,pageSize);
        return bookDao.selectPage(iPage,null);  //null是查询条件
    }
}

④测试:

import com.company.domain.Book;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
public class BookServiceTest {
//    业务层对象
    @Autowired
    private BookService bookService;

    @Test
    void testGetById(){
        //单纯这样的话,会输出一个日志(因为我们开启了MP运行日志),也能看我们查找的数据
         bookService.getById(10086);
        //这样的话,我们看数据会更加清晰(前提是实体类要实现toString方法,getById返回的是一个Book对象)
        System.out.println( bookService.getById(10086));
    }

    @Test  //添加对象
    void testSave(){
        Book book = new Book();
//        这里采用的是主键自增,我们不用手动给主键赋值(数据库默认的是雪花算法)
//        book.setId(10092);
        book.setBookName("信息技术");
        book.setStatue("优秀");

        bookService.save(book);
    }

    @Test  //修改对象
    void testUpdate(){
        Book book = new Book();
        book.setId(10086);
        book.setBookName("zhanghangzhang");

        bookService.update(book);
    }

    @Test  //删除对象
    void testDelete(){
        bookService.delete(10093);//通过id删除
    }

    @Test  //得到全部对象
    void testGetAll(){
        System.out.println( bookService.getAll()); //给null查全部
    }

    @Test  //分页  单纯运行这个是不行的,需要写一个配置类(拦截器)
    void testGetPage(){
        bookService.getPage(2,5); //这样也能输出,是因为我们配置了运行日志
    }

}

二、业务层快速开发

①接口:在这里定义方法

import com.baomidou.mybatisplus.extension.service.IService;
import com.company.domain.Book;

//业务层快速开发
public interface IBookService extends IService<Book> {
//我们在数据层是extends BaseMapper<Book> 和这里不太一样 不要混了
//    如果我们需要的方法他们没有提供,我们可以自己在这里写,之后再IBookServiceImpl中进行实现
//    @Override
//  Boolean save(Book book);   如果这个地方报错了,就说明重名了,我们就换一个名字
//    这样就避免了我们手写方法和他们的方法重合了
}
@Mapper //通过这个实现数据库的操作  里面有数据库中各种各样的操作
public interface BookDao  extends BaseMapper<Book> {//指定泛型才能知道操作谁

}

②实体类:

//@Getter所有的get方法
//@Setter所有的set方法
//@NoArgsConstructor 无参构造
//@AllArgsConstructor//全部的构造

@Data  //get+set+toString+hashcode+equals  但是没有构造方法
@TableName(value = "t_book")
public class Book {
    //    这里的属性名 要和数据库表中的属性名一致,要不然最终的查询结果是null
//    将数据库中的结果对此变量名进行注入
    @TableId(value="id",type = IdType.AUTO)  //代表自增算法
    @TableField(value = "id")
    private int id;
    @TableField(value = "bookName")
    private String bookName;
    @TableField(value = "statue")
    private String statue;

}

③service层:  对接口中的方法进行调用

//业务层快速开发
@Service  //定义bean   ; BookDao是通过这个实现数据库的操作  里面有数据库中各种各样的操作;Book是实体类
//IBookService 是提供的业务层接口
public class IBookServiceImpl extends ServiceImpl<BookDao, Book> implements IBookService {

//    先比较与标准开发,这里不需要自己写基本的增删改查了(这就是一个优势,提高了效率)
//    如果我们需要的方法他们没有,我们仍然要在接口中定义,然后自己写
//    具体怎么写,就是回归到我们上面的标准开发了
//    但是这些方法要在接口中进行实现!!!!!否则就会报错!!!!!
//    @Autowired
//    private BookDao bookDao;
//    @Override
//    public Boolean save(Book book) {
//        //bookDao.insert(book)返回的是影响的行计数  我们让他>0,就说明有影响的数据,就返回true
//        return bookDao.insert(book) >0;
//    }
//
//    @Override
//    public Boolean update(Book book) {
//        return bookDao.updateById(book) >0;
//    }
//
//    @Override
//    public Boolean delete(Integer id) {
//        return bookDao.deleteById(id) >0;
//    }
//
//    @Override
//    public Book getById(Integer id) {
//        return bookDao.selectById(id);
//    }
//
//    @Override
//    public List<Book> getAll() {
//        return bookDao.selectList(null);// null说明查询的时候没有条件,那这就是 查询全部数据
//    }
//
//    @Override //分页操作
//    public IPage<Book> getPage(int currentPage, int pageSize) {
//        IPage iPage = new Page(currentPage,pageSize);
//        return bookDao.selectPage(iPage,null);  //null是查询条件
//    }

}

④测试:

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.company.domain.Book;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
public class IBookServiceTest {
    //    业务层对象
    @Autowired
    private IBookService iBookService;

    @Test
    void testGetById(){
        //单纯这样的话,会输出一个日志(因为我们开启了MP运行日志),也能看我们查找的数据
        iBookService.getById(10086);
        //这样的话,我们看数据会更加清晰(前提是实体类要实现toString方法,getById返回的是一个Book对象)
        System.out.println(  iBookService.getById(10086));
    }

    @Test  //添加对象
    void testSave(){
        Book book = new Book();
//        这里采用的是主键自增,我们不用手动给主键赋值(数据库默认的是雪花算法)
//        book.setId(10092);
        book.setBookName("信息技术");
        book.setStatue("优秀");

        iBookService.save(book);
    }

    @Test  //修改对象
    void testUpdate(){
        Book book = new Book();
        book.setId(10086);
        book.setBookName("zhanghangzhang");

        iBookService.updateById(book);
    }

    @Test  //删除对象
    void testDelete(){
        iBookService.removeById(10093);//通过id删除
    }

    @Test  //得到全部对象
    void testGetAll(){
        System.out.println(  iBookService.list()); //给null查全部
    }

    @Test  //分页  单纯运行这个是不行的,需要写一个配置类(拦截器)
    void testGetPage(){
        IPage<Book> page = new Page<Book>(2,5);
       iBookService.page(page);
        //这样也能输出,是因为我们配置了运行日志
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我爱布朗熊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值