我想使用springboot和mybatis实现在数据库中增加一行内容和删除一行内容的功能,请给出usercontroller,userservice,usermapper,usermapper.xml中的相关代码并解释之。注意:访问本地端口8080时,显示user数据库user表的全部内容,在此界面中有简单的按钮add和delete,点击他们就能增加或删除数据
时间: 2024-03-12 13:50:14 浏览: 135
好的,首先我们需要定义User实体类,包含id、name和age三个属性:
```java
public class User {
private Integer id;
private String name;
private Integer age;
// getter和setter方法省略
}
```
接着,我们需要定义UserMapper接口,该接口用于定义增删改查的方法:
```java
public interface UserMapper {
void insert(User user);
void delete(Integer id);
List<User> selectAll();
User selectById(Integer id);
}
```
然后,我们需要编写UserMapper.xml文件,该文件用于定义具体的SQL语句:
```xml
<mapper namespace="com.example.mapper.UserMapper">
<resultMap id="userMap" type="com.example.entity.User">
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="age" column="age"/>
</resultMap>
<select id="selectAll" resultMap="userMap">
SELECT * FROM user
</select>
<select id="selectById" resultMap="userMap">
SELECT * FROM user WHERE id=#{id}
</select>
<insert id="insert" parameterType="com.example.entity.User">
INSERT INTO user(name, age) VALUES (#{name}, #{age})
</insert>
<delete id="delete" parameterType="int">
DELETE FROM user WHERE id=#{id}
</delete>
</mapper>
```
接着,我们需要定义UserService接口及其实现类:
```java
public interface UserService {
void addUser(User user);
void deleteUser(Integer id);
List<User> getAllUsers();
}
```
```java
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public void addUser(User user) {
userMapper.insert(user);
}
@Override
public void deleteUser(Integer id) {
userMapper.delete(id);
}
@Override
public List<User> getAllUsers() {
return userMapper.selectAll();
}
}
```
最后,我们需要编写UserController类,该类用于处理HTTP请求:
```java
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/all")
public List<User> getAllUsers() {
return userService.getAllUsers();
}
@PostMapping("/add")
public void addUser(@RequestBody User user) {
userService.addUser(user);
}
@PostMapping("/delete")
public void deleteUser(@RequestParam("id") Integer id) {
userService.deleteUser(id);
}
}
```
在该类中,`@GetMapping`注解表示处理HTTP GET请求,`@PostMapping`注解表示处理HTTP POST请求,`@RequestBody`注解表示将HTTP请求体中的JSON数据映射为Java对象,`@RequestParam`注解表示从HTTP请求参数中获取参数值。
在前端界面中,我们可以使用HTML和JavaScript编写一个简单的界面,利用AJAX技术来实现与后端的交互。代码如下:
```html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>User Management</title>
</head>
<body>
<table id="userTable">
<tr>
<th>ID</th>
<th>Name</th>
<th>Age</th>
</tr>
</table>
<br>
<form>
<label for="name">Name:</label>
<input type="text" id="name" name="name">
<label for="age">Age:</label>
<input type="text" id="age" name="age">
<input type="button" value="Add" onclick="addUser()">
</form>
<br>
<form>
<label for="id">ID:</label>
<input type="text" id="id" name="id">
<input type="button" value="Delete" onclick="deleteUser()">
</form>
<script>
function loadUsers() {
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
var users = JSON.parse(this.responseText);
var table = document.getElementById("userTable");
for (var i = 0; i < users.length; i++) {
var user = users[i];
var row = table.insertRow(-1);
var idCell = row.insertCell(0);
var nameCell = row.insertCell(1);
var ageCell = row.insertCell(2);
idCell.innerHTML = user.id;
nameCell.innerHTML = user.name;
ageCell.innerHTML = user.age;
}
}
};
xhttp.open("GET", "/user/all", true);
xhttp.send();
}
function addUser() {
var name = document.getElementById("name").value;
var age = document.getElementById("age").value;
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
location.reload();
}
};
xhttp.open("POST", "/user/add", true);
xhttp.setRequestHeader("Content-type", "application/json");
xhttp.send(JSON.stringify({name: name, age: age}));
}
function deleteUser() {
var id = document.getElementById("id").value;
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
location.reload();
}
};
xhttp.open("POST", "/user/delete?id=" + id, true);
xhttp.send();
}
loadUsers();
</script>
</body>
</html>
```
该界面中,我们使用`XMLHttpRequest`对象来发送HTTP请求,`JSON.parse`函数来将JSON字符串转换为JavaScript对象,以及`location.reload`函数来刷新页面。
阅读全文