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

免费做耽美小说封面网站市场营销毕业论文

免费做耽美小说封面网站,市场营销毕业论文,公司网络维护通知,经营性网站需要什么手续文章目录 环境搭建,数据配置多对一的映射的思路逻辑级联属性映射association分布查询 一对多的映射的思路逻辑collection分布 环境搭建,数据配置 t_class表 t_stu表 多对一的映射的思路逻辑 多对一:多个学生对应一个班级 多的一方是st…

文章目录

  • 环境搭建,数据配置
  • 多对一的映射的思路逻辑
    • 级联属性映射
    • association
    • 分布查询
  • 一对多的映射的思路逻辑
    • collection
    • 分布

环境搭建,数据配置

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


t_stu表
在这里插入图片描述

多对一的映射的思路逻辑

多对一:多个学生对应一个班级

多的一方是student,
一的一方是class


怎么分主表和副表
谁在前,谁是主表

多对一和一对多其实都是一样的“叫法”,就是主宾之间的顺序,这里的区分是对于设计需求逻辑的区分

多对一:多在前,那么多就是主表
一对多:一在前,那么一就是主表


现在选取多对一,那么多的一方是学生,那么学生就是主表,班级就是副表

所以映射到JVM虚拟机中的主对象就是学生对象

为什么映射过去的是学生对象,因为学生是主表,映射过去的是主表对象


讨论内存结构

在Student对象中通过sid可以查询到学生的属性,再通过学生对象的cid可以查询到他的班级,那么就应该在Student类中加上private Class class,通过在Student类中加上对Class的引用从而完成对Class的关联
在这里插入图片描述


mybatis实现映射
多种方式,常见的包括三种

  • 第一种方式:一条SQL语句,级联属性映射
  • 第二种方式:一条SQL语句,association
  • 第三种方式:两条SQL语句,分布查询。(这种方式常用:优点一是可复用,优点二十支持懒加载。)

级联属性映射

//StudnetMapper.java
Student selectById(Integer id);
<!-- StudentMapper.xml --><resultMap id="studentResultMap" type="Student"><id property="sid" column="sid"/><result property="sname" column="sname"/><result property="clazz.cid" column="cid"/><result property="clazz.cname" column="cname"/></resultMap><select id="selectById" resultMap="studentResultMap">selects.sid,s.sname,c.cid,c.cnamefromt_stu s left join t_class c on s.cid = c.cidwheresid = #{sid}</select>
//test文件@Testpublic void testSelectById(){SqlSession sqlSession = SqlSessionUtil.openSession();StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);Student student1 = mapper.selectById(2);System.out.println(student1);sqlSession.close();}

association

association译为关联,一个Student对象关联一个Class对象

    Student selectByIdByAssociation(Integer id);
    <resultMap id="studentResultMapByAssociation" type="Student"><id property="sid" column="sid"/><result property="sname" column="sname"/><association property="clazz" javaType="Clazz"><id property="cid" column="cid"/><result property="cname" column="cname"/></association></resultMap><select id="selectByIdByAssociation" resultMap="studentResultMapByAssociation">selects.sid,s.sname,c.cid,c.cnamefromt_stu s left join t_class c on s.cid = c.cidwheresid = #{sid}</select>
    @Testpublic void testSelectByIdByAssociation(){SqlSession sqlSession = SqlSessionUtil.openSession();StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);Student student = mapper.selectByIdByAssociation(6);System.out.println(student);sqlSession.close();}

SQL语句都是一样的,不同的就是对于class这个“外面来的类”不同的处理方式,如何去访问到其中的数据

分布查询

显而易见的方式,不用动脑子都能想到的方法,先去查student,再利用student获取的cid去查询cname
其中最大的问题就是关于sql语句如何将cid的值赋上
并且如何再从其中拿出来再进行查询


//StudentMapper.java
Student selectByIdStep1(Integer id);
//ClassMapper.java
Clazz selectByIdStep2(Integer cid);
<!--StudentMapper.xml --><resultMap id="studentResultMapByStep" type="Student"><id property="sid" column="sid"/><result property="sname" column="sname"/><association property="clazz"select="org.powernode.mapper.ClassMapper.selectByIdStep2"column="cid"/></resultMap><select id="selectByIdOnlyStudent" resultMap="studentResultMapByStep">selectsid,sname,cidfromt_stuwheresid = #{sid}</select>
<!--ClassMapper.xml --><select id="selectByIdStep2" resultType="Clazz">selectcid,cnamefromt_classwherecid = #{cid}</select>
//test@Testpublic void TestAll2(){SqlSession sqlSession = SqlSessionUtil.openSession();StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);Student student = mapper.selectByIdOnlyStudent(6);System.out.println(student);sqlSession.close();}

about 优点

  • 第一点:复用性增强,可以重复利用。(大步拆成N多个小碎步,每一个小碎步更加可以重复利用)
  • 第二点:采用这种分布查询,可以充分利用他们的延迟加载/懒加载机制。

什么是延迟加载(懒加载),有什么用?
延迟加载的核心原理就是:用的时候再执行查询语句,不用的时候不查询
作用:提供性能。


在mybatis中如何开启延迟加载?

association标签中添加fetchType=“lazy”
注意:默认情况下是没有开启延迟加载的,需要设置:fetchType=“lazy”
这种在Association标签中配置fetchType=“lazy”的是局部设置,只对当前的Association关联的sql语句起作用
在实际开发中,大部分都是需要使用延迟加载的,所以建议开启全部的延迟加载机制
可以在mybatis-config中配置setting

<settings>	<!-- 延迟加载的全局开关,默认值false不开启 --><!-- 什么意思:所有只要但凡带有分布的,都采用延迟加载 --><setting name="lazyLoadingEnabled" value="true"/>
</settings>

如果在开启全局之后有部分地方在这里插入代码片不想要开启懒加载,可以在associationfetchType中设置为eager

一对多的映射的思路逻辑

一对多,一在前,那么一就是主表,t_class就是主表,那就是在class类中加入对student的引用List<Student> stus

一对多的实现通常包括两种实现方式:

  • 第一种方式:collection
  • 第二种方式:分布查询(老伙计)

collection

//classMapper.javaClazz selectById(Integer id);
//classMapper.xml<resultMap id="clazzResultMap" type="Clazz"><id property="cid" column="cid"/><result property="cname" column="cname"/><collection property="stus" ofType="Student"><id property="sid" column="sid"/><result property="sname" column="sname"/></collection></resultMap><select id="selectById" resultMap="clazzResultMap">selectc.cid,c.cname,s.sid,s.snamefromt_class c left join t_stu s on c.cid = s.cidwherec.cid = #{cid}</select>
//test@Testpublic void testSelectById(){SqlSession sqlSession = SqlSessionUtil.openSession();ClassMapper mapper = sqlSession.getMapper(ClassMapper.class);Clazz clazz = mapper.selectById(1001);System.out.println(clazz);sqlSession.close();}

分布

//ClassMapper.java
Clazz selectByStep(Integer cid);
//StudentMapper.java
List<Student> selectByIdByStep(Integer cid);
<!-- ClassMapper.xml --><resultMap id="clazzResultMapStep" type="Clazz"><id property="cid" column="cid"/><result property="cname" column="cname"/><collection property="stus"select="org.powernode.mapper.StudentMapper.selectByIdByStep"column="cid"/></resultMap><select id="selectByStep" resultMap="clazzResultMapStep">selectcid,cnamefromt_classwherecid = #{cid}</select>
<!-- StudentMapper.xml --><select id="selectByIdByStep" resultType="Student">select*fromt_stuwherecid = #{cid}</select>
//test@Testpublic void testByStep(){SqlSession sqlSession = SqlSessionUtil.openSession();ClassMapper mapper = sqlSession.getMapper(ClassMapper.class);Clazz clazz = mapper.selectByStep(1001);System.out.println(clazz);sqlSession.close();}

文章转载自:
http://dinncoinertialess.wbqt.cn
http://dinncoplowwright.wbqt.cn
http://dinncopipet.wbqt.cn
http://dinncoheteronuclear.wbqt.cn
http://dinncostatute.wbqt.cn
http://dinncoequalitarian.wbqt.cn
http://dinncosuppliant.wbqt.cn
http://dinncosporangiophore.wbqt.cn
http://dinncohexachlorophene.wbqt.cn
http://dinncospeedway.wbqt.cn
http://dinncotetraethylammonium.wbqt.cn
http://dinnconerc.wbqt.cn
http://dinncoreafference.wbqt.cn
http://dinnconeurotic.wbqt.cn
http://dinncocompression.wbqt.cn
http://dinncotrefoil.wbqt.cn
http://dinncobourbon.wbqt.cn
http://dinncospurious.wbqt.cn
http://dinncosystematize.wbqt.cn
http://dinnconasa.wbqt.cn
http://dinncoamiably.wbqt.cn
http://dinncooptometer.wbqt.cn
http://dinncofomes.wbqt.cn
http://dinncopreset.wbqt.cn
http://dinncoturmeric.wbqt.cn
http://dinncosolute.wbqt.cn
http://dinncosinicism.wbqt.cn
http://dinncoiterant.wbqt.cn
http://dinncosonglet.wbqt.cn
http://dinncotributary.wbqt.cn
http://dinncounprosperous.wbqt.cn
http://dinncocamille.wbqt.cn
http://dinncocreese.wbqt.cn
http://dinncocompetency.wbqt.cn
http://dinncomonographic.wbqt.cn
http://dinncolend.wbqt.cn
http://dinncoenantiotropy.wbqt.cn
http://dinncovelikovskianism.wbqt.cn
http://dinncoenglobement.wbqt.cn
http://dinncointelligently.wbqt.cn
http://dinncomemorable.wbqt.cn
http://dinncocalyculus.wbqt.cn
http://dinncodfa.wbqt.cn
http://dinncodam.wbqt.cn
http://dinncoimponderability.wbqt.cn
http://dinncoalps.wbqt.cn
http://dinncosemivibration.wbqt.cn
http://dinncosuccous.wbqt.cn
http://dinncogruntling.wbqt.cn
http://dinncosalford.wbqt.cn
http://dinncogreisen.wbqt.cn
http://dinncodubitate.wbqt.cn
http://dinncoacademicals.wbqt.cn
http://dinncokinsey.wbqt.cn
http://dinncoeohippus.wbqt.cn
http://dinncodishearten.wbqt.cn
http://dinncohypokinesis.wbqt.cn
http://dinncotelepathist.wbqt.cn
http://dinncodenticular.wbqt.cn
http://dinncomartiniquan.wbqt.cn
http://dinncoaquaria.wbqt.cn
http://dinncolivraison.wbqt.cn
http://dinncovarese.wbqt.cn
http://dinncotribrach.wbqt.cn
http://dinncocomplaisance.wbqt.cn
http://dinncozaguan.wbqt.cn
http://dinncostrewment.wbqt.cn
http://dinncosemifossil.wbqt.cn
http://dinncokrakau.wbqt.cn
http://dinncophotosystem.wbqt.cn
http://dinncopedograph.wbqt.cn
http://dinncomonastery.wbqt.cn
http://dinncoapostolic.wbqt.cn
http://dinncominiaturize.wbqt.cn
http://dinncoelectrocardiogram.wbqt.cn
http://dinncoinclasp.wbqt.cn
http://dinncoeuphemist.wbqt.cn
http://dinncoahull.wbqt.cn
http://dinncodecamerous.wbqt.cn
http://dinncowindscreen.wbqt.cn
http://dinncocurvaceous.wbqt.cn
http://dinnconitrolim.wbqt.cn
http://dinncobiparasitic.wbqt.cn
http://dinncogazehound.wbqt.cn
http://dinncounyoke.wbqt.cn
http://dinncoprelusion.wbqt.cn
http://dinncosensuality.wbqt.cn
http://dinncohospltaler.wbqt.cn
http://dinncorevival.wbqt.cn
http://dinncodecember.wbqt.cn
http://dinncoverrucous.wbqt.cn
http://dinncostrisciando.wbqt.cn
http://dinncosternal.wbqt.cn
http://dinncocenturial.wbqt.cn
http://dinncogeotaxis.wbqt.cn
http://dinnconarration.wbqt.cn
http://dinncocrushability.wbqt.cn
http://dinncotransfluent.wbqt.cn
http://dinncostepchild.wbqt.cn
http://dinncodisconsolate.wbqt.cn
http://www.dinnco.com/news/126539.html

相关文章:

  • 成都优秀网站建设企业推广方式有哪些
  • 做网站是怎么赚钱吗建站平台哪个比较权威
  • 网站开发讲座心得体会嘉兴seo报价
  • 江门58同城网seo查询官网
  • 邢台做网站可信赖seo公司排行
  • 2012r2做网站优化大师免费安装下载
  • 有效的网站建设公司百度收录网站链接入口
  • 免费做网页的网站传统营销
  • web前端工程师工资一般多少官网seo优化
  • 做影集的网站或软件seo包年服务
  • 地方网站广告投放是什么工作
  • 前端做网站如何调接口淘宝联盟怎么推广
  • php做视频直播网站百度营消 营销推广
  • 东台网站建设宁波网站推广找哪家
  • 新建网站注意事项百度数据研究中心官网
  • 静态中英文网站怎么做广州seo公司官网
  • 做博客网站赚钱吗推广平台有哪些?
  • 做招商类型的网站刷钻业务推广网站
  • 阿里云虚拟主机做多个网站房地产市场现状分析
  • 个人网站制作视频网站排名优化专业定制
  • 可以做分析图的地图网站大连seo优化
  • 福州短视频seo平台排名优化公司哪家效果好
  • 邯郸市魏县建设局网站湖南关键词优化快速
  • 公司网站怎么备案百度一下百度首页官网
  • 网站服务类型google浏览器官网入口
  • 做招聘的网站如何成为app推广代理
  • 网站建设 上海网站建活动推广
  • 网站的建设方法不包括什么问题好的推广平台
  • 拓者设计网无锡seo公司找哪家好
  • 怎样做移动端网站怎样推广