MyBatis系列六: 映射关系多对一

动态SQL语句-更复杂的查询业务需求

  • 官方文档
  • 基本介绍
  • 映射方式
  • 配置Mapper.xml的方式-应用实例
  • 注解的方式实现-应用实例
  • 课后练习

在这里插入图片描述

官方文档

文档地址: https://mybatis.org/mybatis-3/zh_CN/sqlmap-xml.html

基本介绍

●基本介绍
1.项目中多对1的关系是一个基本的映射关系, 也可以理解成1对多
2.User --- Pet: 一个用户可以养多只宠物
3.Dep --- Emp: 一个部门可以有多个员工

●注意细节
1.我们直接讲 双向的多对一的关系, 单向的多对一比双向的多对一简单.
2.在实际的项目开发中, 要求会使用双向的多对一的映射关系
3.说明: 什么是双向的多对一的关系: 比如通过User可以查询到对应的Pet, 返回来, 通过Pet也可以级联查询到对应的User信息.
4.多对多的关系, 是在多对1的基础上扩展即可.

映射方式

1.方式1: 通过配置XxxMapper.xml 实现多对1 [配置方式]
2.方式2: 通过注解的方式实现 多对1 [注解方式]
3.我们都实现代码, 应用举例.

配置Mapper.xml的方式-应用实例

●需求说明: 实现级联查询, 通过userid可以查询到用户信息, 并可以查询到关联的pet信息. 反过来, 通过Petid可以查询到Pet的信息, 并且可以级联查询到它的主人User对象信息
在这里插入图片描述

1.创建user表和pet

USE mybatis;CREATE TABLE `mybatis_user` (
`id` INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(32) NOT NULL DEFAULT ''
)CHARSET=utf8CREATE TABLE `mybatis_pet` (
`id` INT PRIMARY KEY AUTO_INCREMENT,
`nickname` VARCHAR(32) NOT NULL DEFAULT '',
`user_id` INT,
FOREIGN KEY(`user_id`) REFERENCES `mybatis_user`(`id`)
)CHARSET=utf8INSERT INTO `mybatis_user` VALUES (NULL, '宋江'), (NULL, '卢俊义');
INSERT INTO `mybatis_pet` VALUES (NULL, '波斯猫', 1), (NULL, '旺财', 1);
INSERT INTO `mybatis_pet` VALUES (NULL, '斑点猫', 2), (NULL, '花猫', 2);SELECT * FROM `mybatis_user`;
SELECT * FROM `mybatis_pet`;

2.创建com.zzw.entity.Petcom.zzw.entity.User. 这里toString方法有问题, 后面揭晓

@Getter
@Setter
public class Pet {/*** CREATE TABLE `mybatis_pet` (* `id` INT PRIMARY KEY AUTO_INCREMENT,* `nickname` VARCHAR(32) NOT NULL DEFAULT '',* `user_id` INT,* FOREIGN KEY(`user_id`) REFERENCES `mybatis_user`(`id`)* )CHARSET=utf8*/private Integer id;private String nickname;//一个pet对应一个主人 User对象private User user;//toString会造成StackOverFlow//@Override//public String toString() {//    return "Pet{" +//            "id=" + id +//            ", nickname='" + nickname + '\'' +//            ", user=" + user +//            '}';//}
}
@Getter
@Setter
public class User {/*** CREATE TABLE `mybatis_user` (* `id` INT PRIMARY KEY AUTO_INCREMENT,* `name` VARCHAR(32) NOT NULL DEFAULT ''* )CHARSET=utf8*/private Integer id;private String name;//因为一个user可以养多个宠物, mybatis 使用集合体现体现这个关系private List<Pet> pets;//toString会带来麻烦?=>会造成StackOverFlow//@Override//public String toString() {//    return "User{" +//            "id=" + id +//            ", name='" + name + '\'' +//            ", pets=" + pets +//            '}';//}
}

3.创建UserMapperPetMapper

public interface UserMapper {//通过id获取User对象public User getUserById(Integer id);
}
public interface PetMapper {//通过User的id来获取pet对象, 可能有多个, 因此使用List接收public List<Pet> getPetByUserId(Integer userId);//通过pet的id获取pet对象, 同时会查询到pet对象关联的user对象public Pet getPetById(Integer id);
}

4.创建PetMapper.xmlUserMapper.xml

<mapper namespace="com.zzw.mapper.PetMapper"><!--1.配置/实现public List<Pet> getPetByUserId(Integer userId);2.通过User的id来获取pet对象, 可能有多个, 因此使用List接收3.完成的思路和前面大体相同--><resultMap id="petResultMap" type="Pet"><id property="id" column="id"/><result property="nickname" column="nickname"/><association property="user" column="user_id"select="com.zzw.mapper.UserMapper.getUserById"/><!--先写完, 再去实现getUserById方法--></resultMap><select id="getPetByUserId" parameterType="Integer"resultMap="petResultMap">SELECT * FROM `mybatis_pet` WHERE `user_id` = #{userId}</select>
</mapper>
<mapper namespace="com.zzw.mapper.UserMapper"><!--解读1.想一想前面的1对1怎么实现的2.配置/实现public User getUserById(Integer id);3.通过id获取User对象4.思路(1) 先通过user-id 查询得到用户信息 (2) 再根据user-id查询对应的pet信息并映射到List<Pet> pets--><resultMap id="userResultMap" type="User"><id property="id" column="id"/><result property="name" column="name"/><!--解读: 因为pets属性是集合, 因此这里需要使用collection标签来处理1.ofType="Pet" 指定返回的集合中存放的数据类型Pet2.collection 表示 pets 是一个集合3.property="pets" 是返回的user对象的属性 pets4.column="id" select * from `mybatis_user` where `id` = #{id} 返回的id字段对应的值--><collection property="pets" column="id" ofType="Pet"select="com.zzw.mapper.PetMapper.getPetByUserId"/></resultMap><select id="getUserById" parameterType="Integer"resultMap="userResultMap">select * from `mybatis_user` where `id` = #{id}</select>
</mapper>

5.新建UserMapperTest PetMapperTest

public class UserMapperTest {//属性private SqlSession sqlSession;private UserMapper userMapper;//初始化@Beforepublic void init() {sqlSession = MyBatisUtils.getSqlSession();userMapper = sqlSession.getMapper(UserMapper.class);System.out.println("userMapper--" + userMapper);}@Testpublic void getUserById() {User user = userMapper.getUserById(2);System.out.println("user信息--" + user.getId() + "-" + user.getName());List<Pet> pets = user.getPets();for (Pet pet : pets) {System.out.println("养的宠物信息-" + pet.getId() + "-" + pet.getNickname());}if (sqlSession != null) {sqlSession.close();}}
}
public class PetMapperTest {//属性private SqlSession sqlSession;private PetMapper petMapper;//初始化@Beforepublic void init() {sqlSession = MyBatisUtils.getSqlSession();petMapper = sqlSession.getMapper(PetMapper.class);System.out.println("petMapper--" + petMapper.getClass());}@Testpublic void getPetByUserId() {List<Pet> pets = petMapper.getPetByUserId(1);for (Pet pet : pets) {System.out.println("pet信息-" + pet.getId() + "-"  + pet.getNickname());User user = pet.getUser();System.out.println("user信息-" + user.getName());}if (sqlSession != null) {sqlSession.close();}}
}

6.实现getPetById, 体会复用

<!--说明
1. 注意体会resultMap带来好处, 直接复用
2. 配置/实现public Pet getPetById(Integer id);
3. 通过pet的id获取pet对象
-->
<select id="getPetById" parameterType="Integer"resultMap="petResultMap">SELECT * FROM `mybatis_pet` where `id` = #{id};
</select>
@Test
public void getPetById() {Pet pet = petMapper.getPetById(4);System.out.println("pet信息-" + pet.getId() + "-" + pet.getNickname());User user = pet.getUser();System.out.println("主人信息-" + user.getId() + "-" + user.getName());if (sqlSession != null) {sqlSession.close();}
}

注解的方式实现-应用实例

●需求说明: 通过注解的方式来实现下面的多对1的映射关系, 实现级联查询, 通过userid可以查询到用户信息, 并可以查询到关联的pet信息. 反过来, 通过Petid可以查询到Pet的信息, 并且可以级联查询到它的主人User对象信息

说明: 在实际开发中还是 推荐使用配置方式

1.新建com.zzw.mapper.UserMapperAnnotation接口

/*** @author 赵志伟* @version 1.0* UserMapperAnnotation: 使用注解的方式实现多对一*/
public interface UserMapperAnnotation {/*** 1.说明: 注解的形式就是前面xml配置方式的体现* 2.这里同学们可以结合前面xml实现*  <resultMap id="userResultMap" type="User">*         <id property="id" column="id"/>*         <result property="name" column="name"/>*         <collection property="pets" column="id" ofType="Pet"*                     select="com.zzw.mapper.PetMapper.getPetByUserId"/>*     </resultMap>*     <select id="getUserById" parameterType="Integer"*             resultMap="userResultMap">*         select * from `mybatis_user` where `id` = #{id}*     </select>*/@Select("select * from `mybatis_user` where `id` = #{id}")@Results({@Result(id = true, property = "id", column = "id"),@Result(property = "name", column = "name"),//这里请小伙伴注意, pets属性对应的是集合@Result(property = "pets", column = "id",many = @Many(select = "com.zzw.mapper.PetMapperAnnotation.getPetByUserId"))})public User getUserById(Integer id);
}

2.新建com.zzw.mapper.PetMapperAnnotation接口

public interface PetMapperAnnotation {/*** <resultMap id="petResultMap" type="Pet">*     <id property="id" column="id"/>*     <result property="nickname" column="nickname"/>*     <association property="user" column="user_id"*                  select="com.zzw.mapper.UserMapper.getUserById"/>* </resultMap>* <select id="getPetByUserId" parameterType="Integer"*         resultMap="petResultMap">*     SELECT * FROM `mybatis_pet` WHERE `user_id` = #{userId}* </select>*///id = "petResultMap" 就是给我们的Results[Result Map] 指定一个名字//, 目的是为了后面复用@Select("SELECT * FROM `mybatis_pet` WHERE `user_id` = #{userId}")@Results(id = "petResultMap", value = {@Result(id = true, property = "id", column = "id"),@Result(property = "nickname", column = "nickname"),@Result(property = "user", column="user_id",one = @One(select = "com.zzw.mapper.UserMapperAnnotation.getUserById"))})public List<Pet> getPetByUserId(Integer userId);/*** <select id="getPetById" parameterType="Integer"*         resultMap="petResultMap">*     SELECT * FROM `mybatis_pet` where `id` = #{id}* </select>** @ResultMap("petResultMap") 使用/引用我们上面定义的 Results[ResultMap]*/@Select("SELECT * FROM `mybatis_pet` where `id` = #{id}")@ResultMap("petResultMap")public Pet getPetById(Integer id);
}

3.新建 com.zzw.mapper.UserMapperAnnotationTestcom.zzw.mapper.PetMapperAnnotationTest

public class UserMapperAnnotationTest {//属性private SqlSession sqlSession;private UserMapperAnnotation userMapperAnnotation;//初始化@Beforepublic void init() {sqlSession = MyBatisUtils.getSqlSession();userMapperAnnotation = sqlSession.getMapper(UserMapperAnnotation.class);System.out.println("userMapperAnnotation--" + userMapperAnnotation.getClass());}@Testpublic void getUserById() {User user = userMapperAnnotation.getUserById(2);System.out.println("[注解方式]--user信息--" + user.getId() + "-" + user.getName());List<Pet> pets = user.getPets();for (Pet pet : pets) {System.out.println("养的宠物信息-" + pet.getId() + "-" + pet.getNickname());}if (sqlSession != null) {sqlSession.close();}}
}
public class PetMapperAnnotationTest {//属性private SqlSession sqlSession;private PetMapperAnnotation petMapperAnnotation;//初始化@Beforepublic void init() {sqlSession = MyBatisUtils.getSqlSession();petMapperAnnotation = sqlSession.getMapper(PetMapperAnnotation.class);System.out.println("petMapperAnnotation--" + petMapperAnnotation.getClass());}@Testpublic void getPetByUserId() {List<Pet> pets = petMapperAnnotation.getPetByUserId(1);for (Pet pet : pets) {System.out.println("pet信息-" + pet.getId() + "-"  + pet.getNickname());User user = pet.getUser();System.out.println("user信息-" + user.getName());}if (sqlSession != null) {sqlSession.close();}}@Testpublic void getPetById() {Pet pet = petMapperAnnotation.getPetById(4);System.out.println("pet信息-" + pet.getId() + "-" + pet.getNickname());User user = pet.getUser();System.out.println("主人信息-" + user.getId() + "-" + user.getName());if (sqlSession != null) {sqlSession.close();}}
}

课后练习

1.自己设计表 dept(部门) 和 emp(雇员), 是1对多的关系
2.通过查询dept, 可以级联查询得到所有emp的信息
3.通过查询emp, 可以级联查询得到对应的dept信息
4.字段小伙伴可以自己设计, 尽量完成.
- dept(id, dep_name)
- emp(id, name, salary, dept_id)

●代码实现
1.创建 dept表 和 emp

USE mybatis;CREATE TABLE `dept` (
`id` INT PRIMARY KEY AUTO_INCREMENT,
`dep_name` VARCHAR(64) NOT NULL DEFAULT ''
)CHARSET=utf8CREATE TABLE `emp` (
`id` INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(64) NOT NULL DEFAULT '',
`salay` DOUBLE NOT NULL DEFAULT 0.0,
`dept_id` INT,
FOREIGN KEY(`dept_id`) REFERENCES `dept`(`id`)
)CHARSET=utf8INSERT INTO `dept` VALUES (1, '宣传部'), (2, '技术部');
INSERT INTO `emp` VALUES (1, '赵志伟', 6000, 2), (2, '赵培竹', 6000, 1), (3, '阳光', 12000, 2), (4, '月亮', 12000, 1);SELECT * FROM `dept`;
SELECT * FROM `emp`;

2.创建com.zzw.entity.dept.javacom.zzw.entity.emp.java

@Getter
@Setter
public class Dept {private Integer id;private String depName;//级联查询, 一对多private List<Emp> emps;
}
@Getter
@Setter
public class Emp {private Integer id;private String name;private Double salary;//级联查询, 一对一private Dept dept;
}

3.创建EmpMapper.javaDeptMapper.java

public interface EmpMapper {//通过emp的id查询到emp对象, 同时会查询到emp对象关联的dept对象public Emp getEmpById(Integer id);//通过dept的id获取emp对象, 可能有多个, 因此用List接收public List<Emp> getEmpByDeptId(Integer deptId);
}
public interface DeptMapper {//通过dept的id查询到dept对象public Dept getDeptById(Integer id);
}

4.创建EmpMapper.xmlDeptMapper.xml

<mapper namespace="com.zzw.mapper.EmpMapper"><!--1.配置/实现public List<Emp> getEmpByDeptId(Integer deptId);2.通过dept的id获取emp对象, 可能有多个, 因此用List接收--><resultMap id="EmpResultMap" type="Emp"><id property="id" column="id"/><result property="name" column="name"/><result property="salary" column="salary"/><association property="dept" column="dept_id"select="com.zzw.mapper.DeptMapper.getDeptById"/></resultMap><select id="getEmpByDeptId" parameterType="Integer" resultMap="EmpResultMap">SELECT * FROM `emp` WHERE dept_id = #{deptId}</select>
</mapper>
<mapper namespace="com.zzw.mapper.EmpMapper"><!--1.配置/实现public Dept getDeptById(Integer id);2.通过dept的id查询到dept对象3.思路(1) 先通过dept-id 查询到部门信息 (2) 再根据dept-id查询对应的emp信息并映射到List<Emp> emps--><resultMap id="DeptResultMap" type="Dept"><id property="id" column="id"/><result property="depName" column="dep_name"/><!--解读: 因为emps属性是集合, 因此这里需要使用collection标签来处理1.ofType="Emp" 指定返回的集合中存放的数据类型Emp2.collection 表示 emps 是一个集合3.property="emps" 是返回的dept对象的属性 emps4.column="id" SELECT * FROM `dept` WHERE `id` = #{id} 返回的id字段的值--><collection property="emps" column="id" ofType="Emp"select="com.zzw.mapper.EmpMapper.getEmpByDeptId"/></resultMap><select id="getDeptById" parameterType="Integer" resultMap="DeptResultMap">SELECT * FROM `dept` WHERE `id` = #{id}</select>
</mapper>

5.创建EmpMapperTestDeptMapperTest

public class EmpMapperTest {//属性private SqlSession sqlSession;private EmpMapper empMapper;//编写方法完成初始化@Beforepublic void init() {sqlSession = MyBatisUtils.getSqlSession();empMapper = sqlSession.getMapper(EmpMapper.class);System.out.println("empMapper=" + empMapper.getClass());}@Testpublic void getEmpByDeptId() {List<Emp> emps = empMapper.getEmpByDeptId(2);for (Emp emp : emps) {System.out.println("emp信息-" + emp.getId() + "-" + emp.getName() + "-" + emp.getSalary());Dept dept = emp.getDept();System.out.println("部门信息-" + dept.getId() + "-" + dept.getDepName());}if (sqlSession != null) {sqlSession.close();}}
}
public class DeptMapperTest {//属性private SqlSession sqlSession;private DeptMapper deptMapper;//编写方法完成初始化@Beforepublic void init() {sqlSession = MyBatisUtils.getSqlSession();deptMapper = sqlSession.getMapper(DeptMapper.class);System.out.println("deptMapper=" + deptMapper.getClass());}@Testpublic void getDeptById() {Dept dept = deptMapper.getDeptById(1);System.out.println("部门信息-" + dept.getId() + "-" + dept.getDepName());List<Emp> emps = dept.getEmps();for (Emp emp : emps) {System.out.println("员工信息-" + emp.getId() + "-" + emp.getName() + "-" + emp.getSalary());}if (sqlSession != null) {sqlSession.close();}}
}

6.实现getEmpById, 体会复用

<!--
1.配置/实现public Emp getEmpById(Integer id);
2.通过emp的id查询到emp对象, 同时会查询到emp对象关联的dept对象
-->
<select id="getEmpById" parameterType="Integer" resultMap="EmpResultMap">SELECT * FROM `emp` WHERE `id` = #{id}
</select>
@Test
public void getEmpById() {Emp emp = empMapper.getEmpById(2);System.out.println("emp信息-" + emp.getId() + "-" + emp.getName() + "-" + emp.getSalary());Dept dept = emp.getDept();System.out.println("部门信息-" + dept.getId() + "-" + dept.getDepName());if (sqlSession != null) {sqlSession.close();}
}

注解方式实现

1.新建EmpMapperAnnotation接口

public interface EmpMapperAnnotation {/*** 通过emp的id查询到emp对象, 同时会查询到emp对象关联的dept对象* <select id="getEmpById" parameterType="Integer" resultMap="EmpResultMap">*     SELECT * FROM `emp` WHERE `id` = #{id}* </select>*/@Select("SELECT * FROM `emp` WHERE `id` = #{id}")@ResultMap("EmpResultMap")public Emp getEmpById(Integer id);/*** 通过dept的id获取emp对象, 可能有多个, 因此用List接收* <resultMap id="EmpResultMap" type="Emp">*     <id property="id" column="id"/>*     <result property="name" column="name"/>*     <result property="salary" column="salary"/>*     <association property="dept" column="dept_id"*                  select="com.zzw.mapper.DeptMapper.getDeptById"/>* </resultMap>* <select id="getEmpByDeptId" parameterType="Integer" resultMap="EmpResultMap">*     SELECT * FROM `emp` WHERE dept_id = #{deptId}* </select>*/@Select("SELECT * FROM `emp` WHERE dept_id = #{deptId}")@Results(id = "EmpResultMap", value = {@Result(id = true, property = "id", column = "id"),@Result(property = "name", column = "name"),@Result(property = "salary", column = "salary"),@Result(property = "dept", column = "dept_id",one = @One(select = "com.zzw.mapper.DeptMapperAnnotation.getDeptById"))})public List<Emp> getEmpByDeptId(Integer deptId);
}

2.新建DeptMapperAnnotation接口

public interface DeptMapperAnnotation {/**通过dept的id查询到dept对象* <resultMap id="DeptResultMap" type="Dept">*     <id property="id" column="id"/>*     <result property="depName" column="dep_name"/>*     解读: 因为emps属性是集合, 因此这里需要使用collection标签来处理*     1.ofType="Emp" 指定返回的集合中存放的数据类型Emp*     2.collection 表示 emps 是一个集合*     3.property="emps" 是返回的dept对象的属性 emps*     4.column="id" SELECT * FROM `dept` WHERE `id` = #{id} 返回的id字段的值*     -->*     <collection property="emps" column="id" ofType="Emp"*                 select="com.zzw.mapper.EmpMapper.getEmpByDeptId"/>* </resultMap>* <select id="getDeptById" parameterType="Integer" resultMap="DeptResultMap">*     SELECT * FROM `dept` WHERE `id` = #{id}* </select>*/@Select("SELECT * FROM `dept` WHERE `id` = #{id}")@Results(id = "DeptResultMap", value = {@Result(id = true, property = "id", column = "id"),@Result(property = "depName", column = "dep_name"),@Result(property = "emps", column = "id",many = @Many(select = "com.zzw.mapper.EmpMapperAnnotation.getEmpByDeptId"))})public Dept getDeptById(Integer id);
}

3.新建 com.zzw.mapper.EmpMapperAnnotationTestcom.zzw.mapper.DeptMapperAnnotationTest

public class EmpMapperAnnotationTest {//属性private SqlSession sqlSession;private EmpMapperAnnotation empMapperAnnotation;//编写方法完成初始化@Beforepublic void init() {sqlSession = MyBatisUtils.getSqlSession();empMapperAnnotation = sqlSession.getMapper(EmpMapperAnnotation.class);System.out.println("empMapperAnnotation=" + empMapperAnnotation.getClass());}@Testpublic void getEmpByDeptId() {List<Emp> emps = empMapperAnnotation.getEmpByDeptId(2);for (Emp emp : emps) {System.out.println("[注解方式]emp信息-" + emp.getId() + "-" + emp.getName() + "-" + emp.getSalary());Dept dept = emp.getDept();System.out.println("部门信息-" + dept.getId() + "-" + dept.getDepName());}if (sqlSession != null) {sqlSession.close();}}@Testpublic void getEmpById() {Emp emp = empMapperAnnotation.getEmpById(2);System.out.println("[注解方式]emp信息-" + emp.getId() + "-" + emp.getName() + "-" + emp.getSalary());Dept dept = emp.getDept();System.out.println("[注解方式]dept信息-" + dept.getId() + "-" + dept.getDepName());if (sqlSession != null) {sqlSession.close();}}
}
public class DeptMapperAnnotationTest {//属性private SqlSession sqlSession;private DeptMapperAnnotation deptMapperAnnotation;//编写方法完成初始化@Beforepublic void init() {sqlSession = MyBatisUtils.getSqlSession();deptMapperAnnotation = sqlSession.getMapper(DeptMapperAnnotation.class);System.out.println("deptMapperAnnotation=" + deptMapperAnnotation.getClass());}@Testpublic void getDeptById() {Dept dept = deptMapperAnnotation.getDeptById(1);System.out.println("[注解方式]dept信息-" + dept.getId() + "-" + dept.getDepName());List<Emp> emps = dept.getEmps();for (Emp emp : emps) {System.out.println("[注解方式]emp信息-" + emp.getId() + "-" + emp.getName() + "-" + emp.getSalary());}if (sqlSession != null) {sqlSession.close();}}
}

接下来我们学习, mybatis缓存…在这里插入图片描述
💐💐💐💐💐💐💐💐给个赞, 点个关注吧, 各位大佬!💐💐💐💐💐💐💐💐

💐💐💐💐💐💐💐💐祝各位2024年大吉大运💐💐💐💐💐💐💐💐💐💐
请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/31901.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

领先GPT-4o:Anthropic 推出新一代模型 Claude 3.5 Sonnet|TodayAI

Anthropic&#xff0c;全球领先的人工智能实验室之一&#xff0c;近日发布了其最新的人工智能模型——Claude 3.5 Sonnet。该模型不仅速度更快&#xff0c;成本更低&#xff0c;而且在多个关键任务上的表现超过了其前代模型 Claude 3 Opus。 更强的视觉功能与幽默感 Claude 3…

Python基础教程(二十九):operator模块

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝你生活愉快&#xff01; &#x1f49d;&#x1f49…

Upload-Labs-Linux1 使用 一句话木马

解题步骤&#xff1a; 1.新建一个php文件&#xff0c;编写内容&#xff1a; <?php eval($_REQUEST[123]) ?> 2.将编写好的php文件上传&#xff0c;但是发现被阻止&#xff0c;网站只能上传图片文件。 3.解决方法&#xff1a; 将php文件改为图片文件&#xff08;例…

白嫖游戏指南,Epic喜加二:《Freshly Frosted》《Rumble Club》

前言 Epic喜加二&#xff1a;《Freshly Frosted》《Rumble Club》《Freshly Frosted》简介&#xff1a; 《Rumble Club》简介&#xff1a; 前言 接下来有时间会分享一些游戏相关可以白嫖的资源&#xff0c;包括游戏本体、游戏素材资源等等。 有需要的小伙伴可以关注这个专栏&…

IP SSL证书使用率大幅度提升

IP SSL证书的使用人数在增长&#xff0c;这一趋势背后有几个推动因素&#xff1a; 1.网络安全意识提升&#xff1a;随着网络安全事件频发&#xff0c;用户和企业对数据保护的重视程度日益增加。IP SSL证书能为基于IP地址直接访问的网站或服务提供加密&#xff0c;有助于防止数据…

没等来百度惊艳的All in AI,却等来了国产之光的盘古大模型 5.0

6月21日&#xff0c;华为开发者大会&#xff08;HDC 2024&#xff09;在广东东莞正式开幕。盘古大模型5.0的更新&#xff0c;也是此次HDC2024的另一项重头戏。在过去的一年中&#xff0c;盘古大模型正在疯狂向各行各业渗透。 此次&#xff0c;华为方面展示了他们在具身智能、医…

七连发吴谨言专访揭秘

七连发&#xff01;吴谨言专访揭秘&#xff0c;薛芳菲魅力再升级在娱乐圈的繁星中&#xff0c;总有那么一些独特的光芒&#xff0c;她们用才华和魅力照亮前行的道路。近日&#xff0c;备受瞩目的“六公主”平台连续发布了七条关于吴谨言的专访&#xff0c;引发了广大网友的热烈…

Java学习笔记(一)Java内容介绍、程序举例、DOS命令、Java跨平台特性的本质、课后练习

Hi i,m JinXiang ⭐ 前言 ⭐ 本篇文章主要介绍Java内容介绍、程序举例、DOS命令、Java跨平台特性的本质还有几道课后练习详细介绍以及部分理论知识 🍉欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁 🍉博主收将持续更新学习记录获,友友们有任何问题可以在评论区留言 …

【C++】平衡二叉树(AVL树)的实现

目录 一、AVL树的概念二、AVL树的实现1、AVL树的定义2. 平衡二叉树的插入2.1 按照二叉排序树的方式插入并更新平衡因子2.2 AVL树的旋转2.2.1 新节点插入较高左子树的左侧&#xff08;LL平衡旋转&#xff09;2.2.2 新节点插入较高右子树的右侧&#xff08;RR平衡旋转&#xff09…

leetcode 二分查找·系统掌握 猜数字大小

题目&#xff1a; 题解&#xff1a; 使用最经典普通二分即可 int guessNumber(int n) {long l0,rn,mid;while(l<r){mid(rl)>>1;if(guess(mid)0)return mid;else if(guess(mid)-1)rmid-1;else lmid1;}return 0;}

全流程FVCOM水环境、污染物迁移、水交换、水质、潮流、温盐、波浪及泥沙数值模拟

近年来&#xff0c;随着计算技术的发展和对海洋、水环境问题认识的加深&#xff0c;数值模拟技术在海洋、水环境等科学研究中的应用越来越广泛。FVCOM因其独特的优点&#xff0c;成为研究海洋动力过程、污染物扩散、水质变化等问题的重要工具。作为一种基于有限体积法的数值模型…

第2章 Android应用的界面编程

&#x1f308;个人主页&#xff1a;小新_- &#x1f388;个人座右铭&#xff1a;“成功者不是从不失败的人&#xff0c;而是从不放弃的人&#xff01;”&#x1f388; &#x1f381;欢迎各位→点赞&#x1f44d; 收藏⭐️ 留言&#x1f4dd; &#x1f3c6;所属专栏&#xff1…

媒体邀约有啥要注意的

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 媒体宣传加速季&#xff0c;100万补贴享不停&#xff0c;一手媒体资源&#xff0c;全国100城线下落地执行。详情请联系胡老师。 媒体邀约是邀请媒体参与活动或报道的重要过程&#xff0c…

搜索引擎推广基本概念与方法分享-华媒舍

销量是每个企业及个人在商业领域中追求的目标之一。而引擎霸屏推广就是一种高效的手段&#xff0c;通过该方法可以助你实现销量的狂揽。本文将为你科普引擎霸屏推广的基本概念与方法&#xff0c;帮助你了解如何运用这一有效的推广策略。 一、引擎霸屏推广 引擎霸屏推广指的是在…

【中学教资科目二】02中学课程

02中学课程 第一节 课程概述1.1 课程的分类 第二节 课程组织2.1 课程内容的文本表现形式2.2 课程评价 第三节 基础教育课程改革3.1 基础教育改革的目标3.2 新课改的课程结构 第一节 课程概述 1.1 课程的分类 学校课程有多种类型&#xff0c;其中最利于学生系统掌握人类所取得的…

软件缺陷及JIRA工具

一、软件缺陷及跟踪流程 1&#xff0c;软件缺陷信息 案例 &#xff08;1&#xff09;缺陷报告的基本内容 缺陷的标题 预置条件 重现步骤 期望结果 实际结果 &#xff08;2&#xff09;软件缺陷的状态 新建 打开 修复 关闭 &#xff08;3&#xff09;软件缺陷的严重程度 …

NeRF从入门到放弃2:InstantNGP

原始的NeRF每条光线上的点都要经过MLP的查询&#xff0c;才能得到其密度和颜色值&#xff0c;要查询的点非常多&#xff0c;而MLP的推理是比较耗时的。 InstantNGP将空间划分成多个层级的体素&#xff08;voxels&#xff09;&#xff0c;并且在每个体素内部使用神经网络来预测…

深入理解前端缓存

前端缓存是所有前端程序员在成长历程中必须要面临的问题&#xff0c;它会让我们的项目得到非常大的优化提升&#xff0c;同样也会带来一些其它方面的困扰。大部分前端程序员也了解一些缓存相关的知识&#xff0c;比如&#xff1a;强缓存、协商缓存、cookie等&#xff0c;但是我…

CTFHUB-SSRF-POST请求

通过file协议访问flag.php文件内容 ?urlfile:///var/www/html/flag.php 右键查看页面源代码 需要从内部携带key发送post数据包即可获得flag ?urlhttp://127.0.0.1/flag.php 得到了key 构造POST请求数据包&#xff0c;进行url编码&#xff08;新建一个txt文件&#xff0c;…

电力电源需要挑战的8大常见问题

电力电源需要挑战的8大常见问题 引言 如果说发电厂输出的是“干净”高质量的电源,但经过输配电,受天气、用户设备、人为因素损坏影响,电压过冲、跌落、中断、共模噪声等电源质量问题就相当突出。尤其在工业环境中,电源质量一般更差,不能忽视的是早年设计的大楼配电,已不能…