Mybatis进阶3--注解开发

先看:

Mybatis进阶1-CSDN博客

Mybatis进阶2-CSDN博客

mybatis注解开发

前置:不需要xxxMapper..xml文件(映射文件)

在核心配置文件中:<mappers>标签只能使用:<package name="扫描的包"/>;

@Insert注解

@Insert("插入的sql语句")

BrandMapper接口:

 /**** @param brand 品牌类型* @return 返回受改变的行数*/@Insert("insert into brand(name, people, status) VALUE (#{name},#{people},#{status})")public int addBrand(Brand brand);

测试:
 

 @Testpublic void testaddBrand(){SqlSession sqlSession=MybatisUtil.openSession();BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);Brand brand=new Brand();brand.setName("小米");brand.setPeople(200);brand.setStatus(1);int i = mapper.addBrand(brand);if(i>0){System.out.println("添加成功");sqlSession.commit();}sqlSession.close();}

结果:

可见注解开发不用写Mapper.xml(映射文件) 

@Select注解

BrandMapper接口:
 

 /*** 查询所有品牌信息* @return 返回品牌数组*/@Select("select id, name, people, status from brand;")public List<Brand> findAllBrand();/*** 根据品牌id查询某个品牌的全部信息* @param id 要查询品牌的id* @return 返回某个品牌对象*/@Select("select id, name, people, status from brand where id=#{id};")public Brand findBrandById(int id);/*** 根据多条件查询数据* @param name 品牌名* @param status 品牌状态* @return 返回品牌对象*/@Select("select id, name, people, status from brand where name=#{name} and status=#{status};")public Brand findByCondition(@Param("name") String name, @Param("status") int status);

主键回填

 /**** @param brand 品牌类型* @return 返回受改变的行数*/@Insert("insert into brand(name, people, status) VALUE (#{name},#{people},#{status})")@Options(useGeneratedKeys = true,keyColumn = "id",keyProperty = "id")public int addBrand(Brand brand);

keyColumn是主键字段名字,keyProperty是Brand类的成员变量

当查询结果中的列名和实体类的属性名不一致时@Results

1.在SQL语句中,给列名起别名

2.在核心配置文件中,配置驼峰映射(解决下划线)

3.使用resultMap标签,设置查询结果和实体类的映射关系

4.(注解方法):使用@Results注解 

/*** 根据品牌id查询某个品牌的全部信息* @param id 要查询品牌的id* @return 返回某个品牌对象*/@Select("select id as brand_id, name, people, status from brand where id=#{id};")@Results(id="BrandMap",value= {@Result(column = "brand_id",property = "id",id = true),//id属性是表明该字段是主键@Result(column = "name",property = "name")})public Brand findBrandById(int id);

 模糊查询

select id, name, people, status from brand where name like '%华%';
select id,name,people,status from brand where name like concat('%','华','%');

这两种方法都可以进行模糊查询,但是在java开发中,我们使用第二种,这样才可以使用

#{key}的方式取值。

/*** 通过name模糊查询* @param name 要查询的名字* @return 返回Brand对象数组*/@Select("select id,name,people,status from brand where name like concat('%',#{name},'%')")public List<Brand> findBrandByLike(String name);

测试

 @Testpublic void testFindBrandByLike(){SqlSession sqlSession = MybatisUtil.openSession();BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);List<Brand> brands = mapper.findBrandByLike("华");for (Brand brand : brands) {System.out.println(brand);}}

动态sql

我们要模糊查询某个品牌的名字,如果没有输入名字,,就查询status为1的所有品牌名

这个需求就需要使用动态SQL语句了

我们需要在dao层新创建一个MySqlProvider类

public class MySqlProvider {public String findNameByLike( String name)//拼接字符串{String sql="select id, name, people, status from brand where status=1 ";if(name!=null&&!(name.equals(""))){sql+=" and name like concat('%',#{name},'%')";}return sql;}
}

 BrandMapper接口

    @SelectProvider(type = MySqlProvider.class,method = "findNameByLike")//接收组装后的sql语句public List<Brand> findBrandByLike( String name);

@selectProvider源码

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
public @interface SelectProvider {Class<?> type();String method() default "";
}

测试

 @Testpublic void testFindBrandByLike(){SqlSession sqlSession = MybatisUtil.openSession();BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);List<Brand> brands = mapper.findBrandByLike(null);for (Brand brand : brands) {System.out.println(brand);}}

结果:

权限管理

1.权限        //相当于 职责

2.用户        //相当于 职员(职员就职于一个职位)

3.角色        //相当于 职位(有多个职责) 

权限管理基础表:权限表,用户表,角色表

问题1:一个用户可以有多个角色吗  y

问题2:一个角色可以被多个用户使用吗 y

问题3:一个角色可以有多个权限吗 y

问题4:一个权限可以被多个角色使用 y

权限管理需要的表:用户表<=用户角色表=>角色表<=角色权限表=>权限表

这就是权限5张表

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

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

相关文章

25考研英语长难句Day01

Day01 【思考】&#xff1a;本句中有几处平行结构&#xff1f;分别是什么和什么平行并列呢&#xff1f;【生词、词组】【断开、简化】&#xff08; 两步分析法&#xff09;断开长难句的三步法&#xff1a;标点、连接词、分析主谓平行结构 【思考】&#xff1a;本句中有几处平行…

Who calls ActivityRecord#removeIfPossible

activityDestroyed when you call finish . ActivityClientController#activityDestroyed ActivityRecord#destroyed app died:

手把手教你响应式网页设计:详细指南

响应式设计是如今网页设计的大趋势&#xff0c;现在已经成为网页设计师学习的焦点。响应式网页设计考虑到多平台、多种屏幕尺寸的情况&#xff0c;能够优化多种设备的网络浏览体验。在进行响应式设计时&#xff0c;要专门针对内容进行设计&#xff0c;优先考虑在不同环境下内容…

机器学习之基于Python多种混合模型的糖尿病预测

欢迎大家点赞、收藏、关注、评论啦 &#xff0c;由于篇幅有限&#xff0c;只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景 糖尿病是一种慢性代谢性疾病&#xff0c;其发病率在全球范围内逐年上升&#xff0c;已成为影响人类健…

基于python+django网易新闻+评论的舆情热点分析平台

博主介绍&#xff1a; 大家好&#xff0c;本人精通Java、Python、C#、C、C编程语言&#xff0c;同时也熟练掌握微信小程序、Php和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我有丰富的成品Java、Python、C#毕设项目经验&#xff0c;能够为学生提供各类…

在Pycharm中使用ARCGIS Pro提供的python.exe或者ArcPy

在安装了ArcGIS Pro后,如果需要在Pycharm中使用Pro提供的python.exe或者ArcPy,还需要进行相关设置,主要是3步:1、克隆python环境;2、Pycharm选择python;3、导入ArcPy等。 详细内容可见: 公众号GISideas 1、克隆python环境 ArcGIS Pro自带的Python版本是无法被修改的,…

Elsevier——投稿系统遇到bug时的解决方法

重要&#xff1a;找期刊客服&#xff01;&#xff01;&#xff01; 一、方法&#xff1a; 1. 点击进入与官方客服的对话 2. 按要求输入个人信息 3. 输入遇到的问题 比如&#xff1a; 主题&#xff1a;The Current Status is jammed. 详细描述&#xff1a;The Current State o…

成功案例(IF=7.3)| 转录组+蛋白质组+代谢组联合分析分析揭示胰腺癌中TAM2相关的糖酵解和丙酮酸代谢重构

研究背景 肿瘤的进展和发展需要癌细胞的代谢重编程&#xff0c;癌细胞能量代谢模式的改变可以满足快速增殖和适应肿瘤微环境的需要。肿瘤微环境&#xff08;TME&#xff09;中的代谢状态受到多种因素的影响&#xff0c;包括血管生成、与其他细胞的相互作用和系统代谢。代谢异质…

CV每日论文--2024.5.6

1、Multi-Space Alignments Towards Universal LiDAR Segmentation 中文标题&#xff1a;多空间对齐向通用激光雷达分割推进 简介&#xff1a;这篇论文提出了一种名为M3Net的框架,旨在实现通用的激光雷达数据分割。这个框架能够在多任务、多数据集和多模态的激光雷达数据上进行…

DDR5内存新标准问世,体验前所未有的数据传输速度

DDR 5&#xff0c;新标准发布 JEDEC 发布了 JESD79-5C DDR5 SDRAM 标准&#xff0c;带来了关键更新&#xff0c;包括&#xff1a;* 增强可靠性和安全性* 优化高性能服务器和新兴技术&#xff08;如 AI 和机器学习&#xff09;的性能* 标准可从 JEDEC 网站下载 JESD79-5C 引入每…

Web前端一套全部清晰 ⑥ day4 CSS.2 复合选择器、CSS特性、背景属性、标签的显示模式

别人的议论&#xff0c;那是别人的&#xff0c;你的人生&#xff0c;才是你的 —— 24.5.7 一、复合选择器 定义&#xff1a;由两个或多个基础选择器&#xff0c;通过不同的方式组合而成 作用&#xff1a;更准确、更高效的选择目标元素&#xff08;标签&#xff09; 1.后代选择…

Leetcode—933. 最近的请求次数【简单】

2024每日刷题&#xff08;128&#xff09; Leetcode—933. 最近的请求次数 实现代码 class RecentCounter { public:RecentCounter() {}int ping(int t) {q.push(t);while(t - 3000 > q.front()) {q.pop();}return q.size();} private:queue<int> q; };/*** Your Re…

Amazon Bedrock 托管 Llama 3 8B70B

Amazon Bedrock 托管 Llama 3 8B&70B&#xff0c;先来体验&#xff1a;&#xff08;*实验环境账号有效期为1天&#xff0c;到期自动关停&#xff0c;请注意重要数据保护&#xff09; https://dev.amazoncloud.cn/experience/cloudlab?id65fd86c7ca2a0d291be26068&visi…

装饰器模式-原理分析以及动手练习

目录 应用场景涉及的角色和类&#xff08;个人理解&#xff09;涉及的角色组件&#xff08;标准&#xff09;基本实现 Demo&#xff08;可以直接 copy 跑一下看效果&#xff09;自己动手实战需求参考答案 相关话题参考文章 应用场景 需要给一个现有类添加附加功能&#xff0c;…

Nginx+GateWay

目录 Nginx nginx如何配置负载均衡 负载均衡有哪些策略 1、轮询&#xff08;默认&#xff09; 2、指定权重 3、ip_hash&#xff08;客户端ip绑定&#xff09; 4、least_conn&#xff08;最少连接&#xff09; 5、fair 6、url_hash Nginx为什么效率高 gateway 使用gat…

学习云计算亚马逊云科技AWS的6大教科书神级别免费网站

亚马逊☁️(AWS)是全球云行业最&#x1f525;火云平台&#xff0c;云行业的就业机会和市场前景都非常巨大&#xff0c;现在通过学AWS去转云会是个千载难逢的好机会。小李哥这次来盘点学习AWS的6大教科书级免费官方网站(免费课程&#xff0b;动手实验)。欢迎大家点击图片左下角加…

QT:label标签/进度条的使用

文章目录 设置不同格式的文本显示图片文本对齐/自动换行/缩进/边距LCDNumber倒计时 ProgressBar进度条 设置不同格式的文本 在文本格式中&#xff0c;存在富文本&#xff0c;makedown格式的文本&#xff0c;还有纯文本&#xff0c;下面就依据这三个进行举例 #include "w…

领鸡蛋游戏养鸡游戏淘宝客源码广告联盟功能介绍

领鸡蛋游戏功能介绍 核心功能 用户鸡蛋数量 玩家在游戏中会累积一定数量的鸡蛋&#xff0c;这些鸡蛋可以通过完成任务、签到、邀请好友等方式获得。鸡蛋数量直接关联到玩家的游戏进度和奖励。足迹 足迹功能展示用户的饲料明细&#xff0c;包括饲料的获取方式、数量以及时间等…

公司数据防泄漏方案分享|防泄密软件有哪些

企业的数据安全是公司稳定发展的必要条件&#xff0c;如何防止内部数据泄露企业的数据安全是公司稳定发展的必要条件&#xff0c;如何防止内部数据泄露已经成为了一个亟待解决的问题。在这个信息时代&#xff0c;数据已经成为企业最重要的资产之一&#xff0c;因此&#xff0c;…

AWS宣布推出Amazon Q :针对商业数据和软件开发的生成性AI助手

亚马逊网络服务&#xff08;AWS&#xff09;近日宣布推出了一项名为“Amazon Q”的新服务&#xff0c;旨在帮助企业利用生成性人工智能&#xff08;AI&#xff09;技术&#xff0c;优化工作流程和提升业务效率。这一创新平台的推出&#xff0c;标志着企业工作方式的又一次重大变…