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

jsp网站建设项目实战总结seo品牌优化百度资源网站推广关键词排名

jsp网站建设项目实战总结,seo品牌优化百度资源网站推广关键词排名,手机网页无法访问如何解决,热点事件舆情分析报告mybatisplus实际上只对单表查询做了增强(速度会更快),从传统的手写sql语句,自己做映射,变为封装好的QueryWrapper。 本篇文章的内容是有两张表,分别是用户表和订单表,在不直接在数据库做表连接的…

mybatisplus实际上只对单表查询做了增强(速度会更快),从传统的手写sql语句,自己做映射,变为封装好的QueryWrapper。
本篇文章的内容是有两张表,分别是用户表和订单表,在不直接在数据库做表连接的情况下,通过后台代码完成①查询订单的同时查到该订单所属的用户,②查询用户的同时查到该用户的订单列表的功能。

Mybatis版本

准备表环境

t_user

在这里插入图片描述

在这里插入图片描述


### t_order

在这里插入图片描述


在这里插入图片描述

编写实体类

Order类

@TableName("t_order")
public class Order {@TableId(type = IdType.AUTO)private int id;private String order_time;private String total;private int uid;@TableField(exist = false)private User user;
  • @TableName表示数据库表名的映射。其实加上与不加都无所谓。因为我们先用的是mybatis,最终会自己写一个方法去映射。
  • @TableId(type = IdType.AUTO)表示该注解下面的字段在数据库是自增的。
  • @TabelField(exist = false)表示该注解下面的字段在数据库中实际是不存在的,mybatis不需要去数据库中映射,我们自己会编写映射方法。

最后记得在类里面自动生成getter和setter还有toString方法。

User类

@TableName("t_user")
public class User {@TableId(type = IdType.AUTO)private int id;private String username;private String password;private String birthday;//描述用户的所有订单@TableField(exist = false)private List<Order>  orders;

@TableName同上,加与不加都无所谓。最后记得在类里面自动生成getter和setter还有toString方法。

编写mapper方法

UserMapper

@Mapper
public interface UserMapper extends BaseMapper<User> {@Update("insert into t_user values (#{id},#{username},#{password},#{birthday})")public int insert(User user);//查询用户及其所有的订单@Select("select * from t_user")@Results({@Result(column = "id",property = "id"),@Result(column = "username",property = "username"),@Result(column = "password",property = "password"),@Result(column = "birthday",property = "birthday"),@Result(column = "id",property = "orders",javaType = List.class,many = @Many(select = "com.example.mybatisplusdemo.mapper.OrderMapper.selectByUid"))})List<User> selectAllUserAndOrders();
}
  • @Result的column代表数据库里的列名,property代表代码里的数据结构。即从数据库里查到的数据映射到代码里的哪个参数。
  • 因为一个用户可能有多个订单,所以最后一个@Result里面写的是的many=@Many。
  • 最后一个@Result表明的意思是mybatis/mybatisplus允许在mapper方法内部继续调用一个mapper方法,把column里查到的数值传给mapper方法,最终后者返回的结果才是真正传给property的值。
  • 注意调用的mapper方法需要写全类名(上篇文章提到过如何快速复制)再加方法名。

OrderMapper

@Select("select * from t_order where uid = #{uid}")
List<Order> selectByUid(int uid);@Select("select * from t_order")@Results({@Result(column = "id",property = "id"),@Result(column = "ordertime",property = "ordertime"),@Result(column = "total",property = "total"),@Result(column = "uid",property = "user",javaType = User.class,one = @One(select = "com.example.mybatisplusdemo.mapper.UserMapper.selectById"))})List<Order> selectAllOrderAndUser();

注意到是one = @One,因为一个订单只对应着一个用户。

编写controller方法

OrderController

@RestController
@CrossOrigin
public class OrderController {@Autowiredprivate OrderMapper orderMapper;@GetMapping("/order/findAll")public List findAll(){List orders = orderMapper.selectAllOrderAndUser();return  orders;}
}

UserController

@RestController
@CrossOrigin
public class UserController {@Autowiredprivate UserMapper userMapper;@GetMapping("/user")public List query(){List<User> list = userMapper.selectList(null);System.out.println(list);return list;}@GetMapping("/user/findAll")public List<User> find(){ return userMapper.selectAllUserAndOrders();}
}

测试

在这里插入图片描述

在这里插入图片描述

MybatisPlus版本做条件查询

mybatisplus提供了封装好的QueryWrapper类,让我们做条件查询或者更新查询。
注意如果想要使用mybatisplus,要把原来实体类里的@TableField加上

编写controller类

UserMapper

@RestController
public class UserController {@Autowiredprivate UserMapper userMapper;@GetMapping("/user/find")public List<User> query() {QueryWrapper<User> queryWrapper = new QueryWrapper<>();queryWrapper.eq("username","zhangsan");// 筛选出用户名为张三的用户。return userMapper.selectList(queryWrapper);}
}

测试

在这里插入图片描述

MybatisPlus版本做分页查询

编写配置类

新建一个软件包config,编写一个配置类

@Configuration
public class MyBatisPlusConfig {@Beanpublic MybatisPlusInterceptor paginationInterceptor(){MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); // 定义一个拦截器PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor(DbType.MYSQL); //告诉它数据库类型interceptor.addInnerInterceptor(paginationInnerInterceptor);// 拦截器注册return interceptor;}
}

在controller里面添加方法

在UserController中添加分页查询方法

@GetMapping("user/findByPage")public IPage findByPage(){Page<User> page = new Page<>(0,2); // 设置起始值和每页条数IPage iPage = userMapper.selectPage(page,null); // 返回结果集,这里如果想额外增加附属条件//可以写在第二个参数queryWrapper中return iPage;}

测试

在这里插入图片描述

http://www.hengruixuexiao.com/news/5293.html

相关文章:

  • 树莓派做网站服务器性能怎么样java培训学费多少钱
  • 无锡新区网站制作建站平台
  • 网络营销活动策划方案南宁seo网络优化公司
  • 世界十大互联网公司排名seo指的是搜索引擎营销
  • 找素材去哪个网站苏州seo公司
  • 网页制作优质网站优化关键词具体要怎么做
  • 浏阳做网站的公司价格佛山关键词排名工具
  • 设计网站页面设计西安百度推广排名
  • 直播开放平台登录seo网站优化培训公司
  • 网站移动端建设百度账号找回
  • 精品课网站怎么做seo英文全称
  • 网络营销策划要素seo竞争对手分析
  • 南京企业自助建站百度收录提交申请网站
  • 网站搜索引擎优化的步骤现在如何进行网上推广
  • 专业网站设计公司哪里有本地建站软件有哪些
  • 厦门网站制作seo优化的内容有哪些
  • 国务院政府网站建设原则专门培训seo的网站
  • 网站开发需要的知识郑州整站网站优化
  • 网站开发需要哪些人怎么分工做推广哪个平台好
  • 上海网站空间租用seo网站推广方式
  • 东莞培训网windows优化大师是系统软件吗
  • 遵义制作公司网站的公司网络seo外包
  • 微同步网站免费的网站域名查询
  • 菏泽网站建设哪家好竞价排名推广
  • 纳溪区城乡住房建设局网站自己怎么免费做百度推广
  • 江油移动网站建设中国互联网电视app下载安装
  • 网络推广课程培训网络优化工程师证书
  • 景点网站建设方案网络上哪里可以做推广
  • 石家庄公司做网站足球积分排行榜最新
  • 江门网络推广公司廊坊优化外包