package com.chen.springbootjdbc.entity;
import lombok.*;
@Data
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
public class User {
private Long id;
private String name;
private String password;
private int age;
public User(String name, String password, int age) {
this.name = name;
this.password = password;
this.age = age;
}
}
新建dao接口
package com.chen.springbootjdbc.dao;
import com.chen.springbootjdbc.entity.User;
import java.util.List;
public interface UserRepository {
int save(User user);
int update(User user);
int delete(long id);
List<User> findAll();
User findById(long id);
}
新建接口实现类
package com.chen.springbootjdbc.dao.impl;
import com.chen.springbootjdbc.dao.UserRepository;
import com.chen.springbootjdbc.entity.User;
import com.chen.springbootjdbc.entity.mapper.UserRowMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
public class UserRepositoryImpl implements UserRepository {
@Autowired
private JdbcTemplate jdbcTemplate;
@Override
public int save(User user) {
return jdbcTemplate.update("insert into user(name,password,age) values (?,?,?)", user.getName(),
user.getPassword(), user.getAge());
}
@Override
public int update(User user) {
return jdbcTemplate.update("UPDATE users SET name = ? , password = ? , age = ? WHERE id=?", user.getName(), user.getPassword(), user.getAge(), user.getId());
}
@Override
public int delete(long id) {
return jdbcTemplate.update("DELETE FROM users where id = ?",id);
}
@Override
public List<User> findAll() {
return jdbcTemplate.query("SELECT * FROM users", new UserRowMapper());
}
@Override
public User findById(long id) {
return jdbcTemplate.queryForObject("SELECT * FROM users WHERE id=?", new Object[] { id }, new BeanPropertyRowMapper<User>(User.class));
}
}