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

沧州网站建设熊掌号淘宝联盟合作网站api

沧州网站建设熊掌号,淘宝联盟合作网站api,优动网站,返利网站开发一般要多少钱目录 项目场景: 实战操作: 1.创建菜单表 2.创建实体 3.创建Mapper 4.创建xml 属性描述: 效率比较: 项目场景: 本文说明了Spring BootMyBatis使用collection标签的两种使用方法 1. 方法一: 关联查询 2. 方法…

目录

项目场景:

实战操作:

1.创建菜单表

2.创建实体 

3.创建Mapper

4.创建xml 

属性描述:

效率比较:


项目场景:

本文说明了Spring Boot+MyBatis使用collection标签的两种使用方法

1. 方法一: 关联查询
2. 方法二: 嵌套select查询


实战操作:

1.创建菜单表

这里只创建一张表,树结构只有两级,方便学习,多表关联是同样的道理

-- ----------------------------
-- Table structure for menu
-- ----------------------------
DROP TABLE IF EXISTS `menu`;
CREATE TABLE `menu`  (`id` int(11) NOT NULL AUTO_INCREMENT,`name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '角色名称',`pid` int(3) NULL DEFAULT NULL COMMENT '0代表父级',`order` int(3) NULL DEFAULT NULL COMMENT '排序',PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 6 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of menu
-- ----------------------------
INSERT INTO `menu` VALUES (1, '审核', 0, 1);
INSERT INTO `menu` VALUES (2, '栏目管理', 0, 2);
INSERT INTO `menu` VALUES (3, '应用审核', 1, 1);
INSERT INTO `menu` VALUES (4, '服务审核', 1, 2);
INSERT INTO `menu` VALUES (5, '角色管理', 2, 1);

2.创建实体 

package com.test.entity;import lombok.Data;
import java.util.List;@Data
public class Menu {private Integer id;private String name;private Integer pid;private Integer order;private List<Menu> menus;}

3.创建Mapper

package com.test.dao;import com.test.entity.Menu;
import java.util.List;public interface TestMapper{//关联查询List<Menu> selectMenu();//嵌套查询List<Menu> selectNestedMenu();
}

4.创建xml 

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.test.dao.TestMapper"><!-- 公共字段 --><resultMap id="BaseResultMap" type="com.test.entity.Menu"><result column="id" property="id"/><result column="name" property="name"/><result column="pid" property="pid"/><result column="order" property="order"/></resultMap><!-- 方式一、关联查询:执行一次sql --><!-- 定义resultMap --><resultMap id="MenuResultMap" extends="BaseResultMap" type="com.test.entity.Menu"><!-- 关联集合映射,columnPrefix前缀,用于区分相同字段 --><collection ofType="com.test.entity.Menu" resultMap="BaseResultMap" property="menus" columnPrefix="menu_"></collection></resultMap><!-- 查询语句 --><select id="selectMenu" resultMap="MenuResultMap">select r.id ,r.name ,r.pid ,r.order ,r1.id AS menu_id ,r1.name AS menu_name ,r1.pid AS menu_pid,r1.order AS menu_orderFROM menu rLEFT JOIN menu r1 ON r.id = r1.pidwhere r.pid=0order by r.order,r1.order</select><!-- 方式二、嵌套查询:会执行多次sql --><!-- 定义resultMap --><resultMap id="NestedResultMap" extends="BaseResultMap" type="com.test.entity.Menu"><!-- 嵌套查询集合映射 --><collection property="menus" column="id" select="selectChildMenu"/></resultMap><!-- 查询所有父级语句 --><select id="selectNestedMenu" resultMap="NestedResultMap">select r.id ,r.name ,r.pid ,r.orderFROM menu rwhere r.pid=0order by r.order</select><!-- 查询下级 --><select id="selectChildMenu" resultMap="BaseResultMap">select r.id ,r.name ,r.pid ,r.orderFROM menu rwhere r.pid=#{id}order by r.order</select></mapper>

属性描述:

属性描述
property属性名:映射实体类属性名
ofType映射集合的类型(指定一对多的集合里面元素的类型)
column映射数据库字段名,传多个 {“属性名”=“参数”,“属性名”=“参数”}
select用于加载复杂类型属性的映射语句的ID(它会从column 属性指定的列中检索数据,作为参数传递给目标 select 语句)
columnPrefix给关联的数据库中的 column 添加一个前缀(如果不添加前缀,当 两个表同时有 id 字段,查询结果时一定会产生覆盖,使得两个 id 的值一样)

效率比较:

方法一(关联查询):只需要执行一次sql语句。
方法二(嵌套select查询):需要执行多次sql语句。
     
方法一比方法二的效率要高,但是在使用的时候,方法二的代码可重用性要高

比如:这里用的是菜单表,数据量不会太大,可以选择方法二(嵌套select查询)

源码: https://download.csdn.net/download/u011974797/88305627

http://www.yayakq.cn/news/539797/

相关文章:

  • 省级住房城乡建设主管部门网站wordpress 百度cdn
  • 模板网站和定制网站的区别是什么室内设计师收入
  • 公司的网站建设与维护竞价单页网站模板
  • h5手机网站建设是什么意思渠道网络建设策略
  • 网站开发子账号推广普通话手抄报内容简短
  • 网站语言版本广州专业网站建设哪家好
  • 北京市保障性住建设投资中心网站企业网站管理源码
  • 凡客诚品网站建设策划书小米手表网站
  • 网站建设注意细节临沂网站建设搭建
  • 烟台优化网站建设旅游网站怎样做网络宣传
  • 聊城网站设计做一个网站需要怎么做
  • 快站网如何开始建站自助建站网站程序源码
  • 微信公众网站怎么做的wordpress升级不了
  • 建设ca网站wordpress转发分享插件
  • 网站开发制作公司简介博白建设局网站
  • 怎么做质量高的网站廊坊关键词排名首页
  • 广西建设执业注册中心中心网站网站建设 选择题
  • 建一个设计网站要多少钱营销型网站建设的价格
  • 无极网站网站网站建设数据库软件英文
  • 中山做app网站公司吗建筑资料管理规程
  • 甘肃交通工程建设监理有限公司网站个人摄影作品网站
  • 做影视网站需要多大硬盘cpa单页网站怎么做
  • 福建微网站建设价格网站建设源代码交付
  • 海南网站建设基本流程加快网站打开速度
  • 网站和后台建设网络推广策划方案范文
  • 企业网站建设的公司承德 网站建设
  • php如何做视频网站军工企业专业网站建设方案
  • 网站关键字代码怎么0成本做网站
  • 做h5哪个网站好用南充建网站
  • 网站推广产品怎么做企业网站可以个人备案