SpringBoot-JdbcTemplates-MySQL

SpringBoot 中用 JdbcTemplate 訪問MySQL

一. 準備工做mysql

  • IDEA
  • docker : 運行MySql

二. 啓動 docker mysql 容器並進行表的建立web

  1. 啓動 docker,查看docker mysql 鏡像,啓動spring

    - docker images : 查看所有的docker 鏡像
    - docker run -d -p 3333:3306 -e MYSQL_ROOT_PASSWORD=123 mysql:letest(mysql對應的images : id)
    - 啓動 Navicat 鏈接mysql
    - 建立數據庫 springboot,建立表
        create table account(
            id int(11) not null auto_increment,
            name varchar(20) not null,
            money double default null,
            premary key(id)
        ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
        INSERT INTO `account` VALUES ('1', 'aaa', '1000');
        INSERT INTO `account` VALUES ('2', 'bbb', '1000');
        INSERT INTO `account` VALUES ('3', 'ccc', '1000');

三. 使用IDEA 建立 springBoot項目,選擇 web,MySQL,jpa
四. 配置相關的文件sql

  1. 配置 application.ymldocker

    spring:
         datasource:
           driver-class-name: com.mysql.jdbc.Driver
           url: jdbc:mysql://localhost:3333/springboot
           username: root
           password: 123
  2. 配置實體類 類名爲 Account
  3. DAO層
    接口 :數據庫

    public interface IAccountDao {
           int add(Account account);
    
           int update(Account account);
    
           int delete(int id);
    
           Account findAccountById(int id);
    
           List<Account> findAccountList();
       }

    實現類 :springboot

    @Repository
       public class AccountDao implements IAccountDao {
           @Autowired
           private JdbcTemplate jdbcTemplate;
           @Override
           public int add(Account account) {
               int add = jdbcTemplate.update("INSERT INTO account(NAME,money) values(?,?)", new Object[]{account.getName(), account.getMoney()});
               return add;
           }
       
           @Override
           public int update(Account account) {
               String sql = " update account set name = ?,money = ? where id = ?";
               int update = jdbcTemplate.update(sql, new Object[]{account.getName(),account.getMoney(),account.getId()});
               return update;
           }
       
           @Override
           public int delete(int id) {
               String sql = "delete from account where id = ?";
               return jdbcTemplate.update(sql,new Object[]{id});
           }
       
           @Override
           public Account findAccountById(int id) {
               String sql = "select id,name,money from account where id = ?";
               List<Account> query = jdbcTemplate.query(sql, new Object[]{id}, new BeanPropertyRowMapper(Account.class));
               if (query != null){
                   return query.get(0);
               }
               return null;
           }
       
           @Override
           public List<Account> findAccountList() {
               String sql = "select id,name,money from account";
               List<Account> accounts = jdbcTemplate.query(sql,new Object[]{}, new BeanPropertyRowMapper(Account.class));
               return accounts;
           }
       
           public List<Account> find() {
               String sql = "select id,name,money from account";
               List<Account> accounts = jdbcTemplate.query(sql, new Object[]{}, new RowMapper<Account>() {
                   List<Account> lists = new ArrayList<Account>();
                   @Override
                   public Account mapRow(ResultSet resultSet, int i) throws SQLException {
                       Account account = new Account();
                       account.setId(resultSet.getInt(1));
                       account.setName(resultSet.getString(2));
                       account.setMoney(resultSet.getDouble(3));
                       return account;
                   }
               });
               return accounts;
           }
       }
  4. service層
    接口 :app

    public interface IAccountService {
           int add(Account account);
       
           int update(Account account);
       
           int delete(int id);
       
           Account findAccountById(int id);
       
           List<Account> findAccountList();
       }

    實現類 :ide

    @Service
       public class AccountService implements IAccountService {
           @Autowired
           private IAccountDao accountDao;
       
           @Override
           public int add(Account account) {
               return accountDao.add(account);
           }
       
           @Override
           public int update(Account account) {
               return accountDao.update(account);
           }
       
           @Override
           public int delete(int id) {
               return accountDao.delete(id);
           }
       
           @Override
           public Account findAccountById(int id) {
                return accountDao.findAccountById(id);
           }
       
           @Override
           public List<Account> findAccountList() {
               return accountDao.find();
           }
  5. controller層
    控制層post

    @RestController
           @RequestMapping("account")
           public class AccountController {
           
               @Autowired
               private IAccountService accountService;
           
               @RequestMapping(value = "add",method = RequestMethod.POST)
               public int insert(@RequestParam(value = "name")String name,@RequestParam(value = "money") Double money){
                   Account account = new Account();
                   account.setName(name);
                   account.setMoney(money);
                   System.out.println("add");
                   int add = accountService.add(account);
                   return add;
               }
               @RequestMapping(value = "delete",method = RequestMethod.GET)
               public int delete(@RequestParam("id")  int id){
                   System.out.println("delete");
                   return accountService.delete(id);
               }
               @RequestMapping("update")
               public int modify(@RequestParam("id") int id,@RequestParam("name") String name,@RequestParam("money") Double money){
                   System.out.println("update");
                   Account account = new Account();
                   account.setId(id);
                   account.setName(name);
                   account.setMoney(money);
                   return accountService.update(account);
               }
               @RequestMapping(value = "/{id}",method = RequestMethod.GET)
               public Account findOne(@PathVariable("id") int id){
                   System.out.println("queryById");
                   return accountService.findAccountById(id);
               }
               @RequestMapping(value = "findAll",method = RequestMethod.GET)
               public List<Account> findAll(){
                   System.out.println("query");
                   return accountService.findAccountList();
               }
           }

五. 使用postman進行測試

沒有安裝的話可使用 brew cask install postman; 安裝完成後直接打開就能夠了

所有測試經過;

六. 參考

[SpringBoot非官方教程 | 第三篇:SpringBoot用JdbcTemplates訪問Mysql][1]
相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息