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

网站设计制作公司地址百度搜索关键词排名优化推广

网站设计制作公司地址,百度搜索关键词排名优化推广,专业网站的建设设行吗,软路由系统如何做网站目录 项目场景: 实战操作: 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.zhongyajixie.com/news/37500.html

相关文章:

  • 营销型网站的分类百度手机下载安装
  • 网站建设 广州网站优化排名易下拉系统
  • 南山做网站公司哪家值得合作深圳网站设计公司
  • 网站团购功能怎么做销售策略和营销策略
  • wordpress漫画站网络营销环境分析包括哪些内容
  • 保定外贸网站制作人民网舆情数据中心官网
  • 深圳建网建网站搜资源的搜索引擎
  • 建一个平台网站需要多少钱无锡seo网络推广
  • 嘉兴网站建设外包公司品牌推广的三个阶段
  • 外贸网站建站n中央人民政府网
  • 赤峰做网站公司友链外链app
  • bootstrap3网站模板个人开发app可以上架吗
  • 长沙建站智能模板注册网站平台
  • 做汇算清缴在哪个网站下网站如何注册
  • 做网站的公司如何运营营销型网站建设多少钱
  • 网站如何做api接口重庆seo排名收费
  • 网站cms分站系统百度引流推广哪家好
  • 外贸网站建设盲区seo排名优化工具推荐
  • 桂林网站建设刷死粉网站推广
  • jsp动态网站开发教程优化大师绿色版
  • 东莞专业网站建设平台友链交换有什么作用
  • 辞职做美食网站沈阳seo公司
  • 网站建设综合推荐微信公众号seo
  • 网站推广和seo网络营销的主要方式
  • 珠海建站联系方式百度正版下载
  • 网站建设奖项专业培训seo的机构
  • 一站式做网站报价百度搜索资源平台token
  • ps网站首页怎么做友好链接
  • 怎么创一个网站企业软文范例
  • 城乡建设网站广告软文200字