当前位置: 首页 > news >正文

网站转换率六枝做网站

网站转换率,六枝做网站,住建培训网站,网站建设成本核算目录 后端数据增删改查Springboot 实体(entity)类引进添加UserMapper接口 创建对用的UserController注意数据库查询不一致新增数据更新删除postman测试 后端数据增删改查 基于之前构建系统,实现用户数据的CRUD。 打开navicat16,…

目录

  • 后端数据增删改查
    • Springboot 实体(entity)类引进
      • 添加UserMapper接口
    • 创建对用的UserController
    • 注意
    • 数据库查询不一致
    • 新增
    • 数据更新
    • 删除
    • postman测试

后端数据增删改查

基于之前构建系统,实现用户数据的CRUD。

  1. 打开navicat16,新建表sys_user·,表内字段如下图所示,注意创建之后应设置为主键自增
    在这里插入图片描述
  2. 设置create_time为当前时间自动填充。
    在这里插入图片描述
  3. 添加信息
    在这里插入图片描述

Springboot 实体(entity)类引进

在IDEA中创建一个包entity,并新建一个实体类UserEntity。

代码如下

public class UserEntity {private Integer id;private String username;private String password;private String email;private String phone;private String nickname;private String address;private String create_time;private String avatar;private String role;public UserEntity() {}public UserEntity(Integer id, String username, String password, String email, String phone, String nickname, String address, String create_time, String avatar, String role) {this.id = id;this.username = username;this.password = password;this.email = email;this.phone = phone;this.nickname = nickname;this.address = address;this.create_time = create_time;this.avatar = avatar;this.role = role;}public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public String getEmail() {return email;}public void setEmail(String email) {this.email = email;}public String getPhone() {return phone;}public void setPhone(String phone) {this.phone = phone;}public String getNickname() {return nickname;}public void setNickname(String nickname) {this.nickname = nickname;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}public String getCreate_time() {return create_time;}public void setCreate_time(String create_time) {this.create_time = create_time;}public String getAvatar() {return avatar;}public void setAvatar(String avatar) {this.avatar = avatar;}public String getRole() {return role;}public void setRole(String role) {this.role = role;}
}

在这里插入图片描述
也可使用lombok提供的插件,使用@Date
实现上述功能,代码如下:

import lombok.Data;@Data
public class UserEntity {private Integer id;private String username;private String password;private String email;private String phone;private String nickname;private String address;private String create_time;private String avatar;private String role;}

在这里插入图片描述

添加UserMapper接口

在项目目录下建一个mapper包,在此包下建立UserMapper接口,UserMapper接口中代码如下:

@Mapper
public interface UserMapper {@Select("select * from sys_user")List<UserEntity> findAll();
}

在这里插入图片描述
@Mapper:为注入接口注解。
@Select:查询语句注解。

创建对用的UserController

在这里插入图片描述

@Autowiredprivate UserMapper userMapper;@GetMapping("/")public List<UserEntity> index(){return userMapper.findAll();}

注意

这里我们已经开始不使用html文件了,也就不需要插件了,请大家务必记得将这个依赖删除,否则运行的时候就会报错。
在pom文件中删除这个thymeleaf依赖。

在这里插入图片描述
运行前检查连接数据库
在这里插入图片描述
在这里插入图片描述

数据库查询不一致

在这里插入图片描述
在这里插入图片描述
与表内数据不一致,分析原因:
数据库未引入:
在这里插入图片描述
在注解@selectalt+enter弹出如下界面:
在这里插入图片描述
第一次使用这个会自动下载包等待片刻后出现:
在这里插入图片描述

连接成功!
点击Idea右侧与navicat 16 一致说明连接成功
在这里插入图片描述
在这里插入图片描述
这个地方全局与全项目都设置为Mysql
在这里插入图片描述
但是修改后还是有问题,冥思苦想Controller更改代码为:

@Controllerpublic class UserController {@Autowiredprivate UserMapper userMapper;@GetMapping("/user")@ResponseBodypublic List<UserEntity> index(){return userMapper.findAll();}

成功:
在这里插入图片描述
其实也可修改为:

@RestControllerpublic class UserController {@Autowiredprivate UserMapper userMapper;@GetMapping("/")public List<UserEntity> index(){return userMapper.findAll();}}

效果与上诉一致,注意 @RestController相当于@Controller + @ResponseBody但前者无法返回界面只能返回数据

仔细搜索资料@RequestMapping("/user")不好用原因找到,既应改成@RequestMapping("user")输入连接为:http://localhost:8080/user/
修改后代码为:

@RestController
@RequestMapping("user")
public class UserController {@Autowiredprivate UserMapper userMapper;@GetMapping("/")public List<UserEntity> index(){return userMapper.findAll();}}

新增

  1. 在mapper中新增方法代码如下:
    @Insert("insert into sys_user(username,password,email,phone,nickname,address,avatar,role) " +"VALUES(#{username},#{password},#{email},#{phone},#{nickname},#{address},#{avatar},#{role});")//这里只是做测试使用int insert(UserEntity userEntity);

在这里插入图片描述
特别说明: 不管是新增还是更新,这样写是最简单的方式,没有表关联,也还不能实现对个别字段的新增。这时候就需要动态SQL语句,后面会讲xml文件。

  1. 新建UserService类
    新建一个service包,并新建一个UserService类,进行数据业务逻辑。
    在这里插入图片描述
    注意注解位置。
@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public int save(UserEntity userEntity){return userMapper.insert(userEntity);}
}
  1. UserController类添加save接口
    注意添加或者修改使用post,查询一般为get,代码如下:
    @Autowiredpublic UserService userService;@PostMapping//这里做了一个单纯的添加的示例,使用的是mapper中的insert方法,修改也用这个方法public Integer save(@RequestBody UserEntity userEntity){return userService.save(userEntity);}

在这里插入图片描述

数据更新

在这里插入图片描述

    @Update("update sys_user set username=#{username},password=#{password}," +"nickname=#{nickname},email=#{email},phone=#{phone},address=#{address} where id=#{id}")int update(UserEntity userEntity);

在这里插入图片描述

 private UserMapper userMapper;public int save(UserEntity userEntity){//如果user没有id则表明是新增if(userEntity.getId()==null){return userMapper.insert(userEntity);}//否则就是更新else {return userMapper.update(userEntity);}}

使用postman作为测试接口,进行更新测试。这时候就会发现,更新的时候虽然可以实现对ID的判断,但是如果只是更新某一个字段,就会发现,其他的字段值变为空了,这时候就需要动态SQL了,后面XML需要登场了。

删除

在这里插入图片描述

 @Delete("delete from sys_user where id=#{id}")int deleteById(@Param("id") Integer id);

在这里插入图片描述

 public Integer deleteById(Integer id) {return userMapper.deleteById(id);}

在这里插入图片描述

 @DeleteMapping("/{id}")public Integer deleteById(@PathVariable Integer id){return  userService.deleteById(id);}

postman测试


在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
id 为1的数据发生了改变。

在这里插入图片描述
在这里插入图片描述
id 为一数据被删除。

http://www.15wanjia.com/news/163875.html

相关文章:

  • 不用ftp做网站简单动画制作软件app
  • python网站开发视频教程云南南网站开发
  • 广州建网站的公司中小型企业网络拓扑图
  • 永久免费网站推荐wordpress 外链统计
  • 网站建设丶金手指下拉12上海百度嘉定公司网页设计
  • 长沙给中小企业做网站的公司wordpress move导入
  • 网站开发目录过多的缺点网站如何做外链2018
  • 怎么用cms做网站包装设计软件
  • 网站后台更新后主页没有变化中国芗城区城乡建设局网站
  • 做网站和做系统哪个难电子商务平台有哪些
  • 网站建设课程心得wordpress v3.3.1空间上传php
  • php网站模块软件公司
  • 58同城企业网站怎么做的男人和男人做爰漫画网站
  • 个人网站怎么制作教程重庆建设厂
  • 网站开发研究前景手机网站开发需求 百度云盘
  • 自己做网站卖什么好个人网站网站
  • 做网站几个步骤58同城机械加工订单
  • 岳阳网站开发商城梵克雅宝官网旗舰店
  • 网站建设需要知道什么网站注册域名查询
  • 免费摄影网站推荐西安网页设计培训排名
  • 如何建立免费的网站58招聘网最新招聘信息
  • 如何让百度收录自己的网站信息表情制作器
  • 网页设计作品长春seo外包
  • 建设网站预算手机上传视频网站开发
  • 怎样购买网站程序wordpress 编辑器推荐
  • wordpress的主题上传了没有显示河南seo关键词排名优化
  • 番禺区大石做网站宿迁房产网官网
  • 网站建设开发合同书wordpress在本地运行很慢
  • 涪城网站建设vue移动端开发
  • 成都设计公司网站中文域名注册官网