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

Java学习Day19

动态SQL语句标签

1.if 用于根据条件判断是否包括某段 SQL 代码

<if test="checktext !=null and check !=''">

2.<choose>, <when>, <otherwise>类似于 Java 的 switch 语句,用于在多个条件中选择一个。

<select id="getStaffBySalary" resultType="com.easy.bean.Staff">select * from staff<where><!--参数名 salarytext --><choose><when test='salarytext=="低"'>salary &lt;= 5000</when><when test='salarytext=="中"'>salary &gt;5000 and salary &lt;=10000</when><otherwise>salary &gt;10000</otherwise></choose></where></select>

3.<foreach>用于遍历集合并生成多个 SQL 片段。

<insert id="addList">insert into staff(code,name,salary,username,userpass)values<foreach collection ="list" item="item" separator=",">(#{item.code},#{item.name},#{item.salary},#{item.username},#{item.userpass})</foreach></insert>

4.<set>用于在更新 SQL 中动态生成 SET 子句。

       <set><if test='name!=null and name!=""'>name =#{name},</if><if test="salary!=null">salary=#{salary},</if></set>

5.<bind> 标签用于创建新的属性,并将其与现有的参数值关联。

<!-- 重新定义参数内容--><bind name="liketext" value="'%'+checktext+'%'"></bind>

6.<where> 标签用于自动处理 SQL 查询中的 WHERE 子句。这对于动态生成 WHERE 子句特别有用,尤其是当你需要处理条件可能为空的复杂查询时。<where> 标签可以自动添加 WHERE 关键字,并处理不必要的 ANDOR 连接符,从而简化 SQL 查询的编写。

<select id="getStaff" resultType="com.easy.bean.Staff">select * from staff<where><!--编写条件语句 如果有内容,会自动添加where关键字   --><if test="checktext !=null and check !=''"><!-- 重新定义参数内容--><bind name="liketext" value="'%'+checktext+'%'"></bind>name like #{liketext}</if></where></select>

一对一查询和一对多查询  resultMap

1.在一对一映射中,通常有两个表(例如 usersuser_profiles),每个表中的一行数据与另一个表中的一行数据相关联。需要使用 resultMapassociation 元素来实现这个映射关系。

 <resultMap id="staffAndDep" type="com.easy.bean.Staff"><association select="getStaffDep" column="dept_id"  property="dep"></association></resultMap><select id="getStaffDep" resultType="com.easy.bean.Department">select * from department where id = #{dept_id}</select><select id="getStaffAndDep" resultMap="staffAndDep">select * from staff</select>

上述代码使用resultMap通过Staff表中的dept_id和Department表中的id关联两表。

2.在一对多映射中,一个表中的一行数据与另一个表中的多行数据相关联。例如,一个用户可以有多个订单。可以使用 resultMapcollection 元素来实现这个映射关系。

<resultMap id="departmentAndStaff" type="com.easy.bean.Department"><!--        <id column="id" property="depid"></id>--><!--        <result column="name" property="dename"></result>--><result column="id" property="id"></result><collection column="id" select="getDepStaff" property="staffList"></collection></resultMap><select id="getDepStaff" resultType="com.easy.bean.Staff">select * from staff where dept_id=#{id}</select><select id="getDep" resultMap="departmentAndStaff">select * from department</select>

题目整理

SQL执行的顺序是:

1. from

2. join

3. where

4. group by

5. 聚合函数 COUNT(),SUM(),AVG(),MIN(),MAX()

6. having

7. select

8. distinct

9. order by | asc, desc, 默认asc

10. limit n, m(n下标0开始,取m条数据)

between…and…语句用于查询数据范围,遵循全闭合的原则,包括左侧和右侧数据。

order by在排序时,可以使用字段名,也可以使用字段下标,下标从1开始。

Servlet生命周期方法有: init,service,destroy

JSP中的九大内置对象有:request,response,session,application,page,pageContext,config,out,exception

delete与truncate的区别?

1- 功能不同:delete用于删除表中的记录,truncate删除表再重建

2- 影响自增:delete自增不会重置,truncate会重置

3- 事务支持:delete可以回滚,truncate不能回滚

4- 效率:delete慢,truncate快

请求转发与重定向的区别?

1- 发生位置:请求转发发生在服务器内部,是服务器行为;重定向是服务器指挥浏览器,发生在浏览器中。

2- 请求次数:请求转发只有一次请求;重定向要发送两次请求。

3- 浏览器地址:请求转发浏览器地址不变;重定向浏览器会指向重定向后的地址。

4- 请求对象:请求转发多页面共享一对request和response,可以使用request共享数据;重定向每次请求创建不同的request和response,不能使用request共享数据。

5- 范围:请求转发只能在当前项目内进行跳转;重定向可以跨站跳转

Get与Post请求的区别?

1)Get请求参数会使用?和&拼接到url上。Post请求参数放在请求体的Form Data数据域中。

2) Get请求参数必须是字符串。Post请求参数除了可以传递字符串类型的,也可以传递二进制。

3) Get请求参数的长度会受到url长度的限制。Post请求参数长度不会受到客户端浏览器的限制,只要服务器允许。

4) Get安全性低。Post相对安全。

相关文章:

Java学习Day19

动态SQL语句标签 1.if 用于根据条件判断是否包括某段 SQL 代码 <if test"checktext !null and check !"> 2.<choose>, <when>, <otherwise>类似于 Java 的 switch 语句&#xff0c;用于在多个条件中选择一个。 <select id"getSt…...

8.达梦数据库常用SQL

文章目录 前言1. 服务器资源1.1 CPU使用率1.2 内存使用率 2 数据库实例管理2.1 查询版本号2.2 查询ini配置2.3 查询归档配置2.4 数据库实例初始化参数2.5 查看数据库信息2.6 查看数据库实例信息2.7 查看数据库实例信息2.8 查看授权信息2.9 查询页大小&#xff0c;字符集大小2.1…...

深入理解接口测试:实用指南与最佳实践(四)IHRM管理系统实战-项目分析

​ ​ 您好&#xff0c;我是程序员小羊&#xff01; 前言 这一阶段是接口测试的学习&#xff0c;我们接下来的讲解都是使用Postman这款工具&#xff0c;当然呢Postman是现在一款非常流行的接口调试工具&#xff0c;它使用简单&#xff0c;而且功能也很强大。不仅测试人员会使用…...

程序编译及链接

你好&#xff01;感谢支持孔乙己的新作&#xff0c;本文就程序的编译及链接与大家分析我的思路。 希望能大佬们多多纠正及支持 &#xff01;&#xff01;&#xff01; 个人主页&#xff1a;爱摸鱼的孔乙己-CSDN博客 ​ ​ 1.翻译译环境与运行环境 当我们进行程序设计时&…...

route 命令介绍及使用方法

route 命令 作用&#xff1a;用于显示和操作 IP 路由表 &#xff08;show/manipulate the IP routing table&#xff09;。 在命令行下执行 route 命令添加路由&#xff0c;不会永久保存&#xff0c;当网卡重启或者机器重启后&#xff0c;该路由就会失效。 命令参数&#xf…...

力扣热题100_二叉树_226_翻转二叉树

文章目录 题目链接解题思路解题代码 题目链接 226. 翻转二叉树 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 示例 1&#xff1a; 输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xff1a;[4,7,2,9,6,3,1] 示例 2&#xff1a; …...

Java SpringBoot 集成 MinIO 资料

Java SpringBoot 集成 MinIO 资料 一、文档 官方文档CSDN项目示例解除Spring文件上传大小限制 二、个人实战 注意事项&#xff1a; 部署MinIO时会涉及到两个端口号&#xff0c;一个为endpoint的端口&#xff0c;一个为console的端口&#xff0c;注意不要弄混 比如&#xff1a…...

鸿蒙系统开发【加解密算法库框架】安全

加解密算法库框架 介绍 本示例使用ohos.security.cryptoFramework相关接口实现了对文本文件的加解密、签名验签操作。 实现场景如下&#xff1a; 1&#xff09;软件需要加密存储本地文本文件&#xff0c;需要调用加解密算法库框架选择密钥文本文件&#xff0c;对本地文本文…...

C语言——二维数组和字符数组

二维数组 二维数组本质上是一个行列式的组合&#xff0c;也就是二维数组是有行和列两部分构成。二维数组数据是通过行列进行解读。 定义形式&#xff1a; 类型&#xff08;说明符&#xff09; 数组名[行数&#xff08;常量表达式1&#xff09;][列数&#xff08;常量表达式…...

Python 爬虫入门(九):Scrapy安装及使用「详细介绍」

Python 爬虫入门&#xff08;九&#xff09;&#xff1a;Scrapy安装及使用「详细介绍」 前言1. Scrapy 简介2. Scrapy 的安装2.1 环境准备2.2 安装 Scrapy 3. 创建 Scrapy 项目3.1 创建项目3.2 项目结构简介 4. 编写爬虫4.1 创建爬虫4.2 解析数据4.3 运行爬虫 5. 存储数据5.1 存…...

扩展addr2line程序的功能,group_add2line() 脚本的实现

------------------------------------------------------------ author: hjjdebug date: 2024年 08月 05日 星期一 16:19:07 CST descrition: 扩展addr2line程序的功能,group_add2line() 脚本的实现 ------------------------------------------------------------ 扩展addr2…...

idea中修改项目名称

公司最近有个小项目新加了很多功能&#xff0c;在叫原先的项目名有点不合适了。所以在网上查了下资料&#xff0c;发现步骤都比较复杂。自己研究了一下找到了一个相对简单的方法&#xff0c;只需要两步&#xff0c;特此记录一下。 1.修改项目文件夹名称 关闭当前项目&#xff…...

Flink开发语言使用Java还是Scala合适?

目录 1. Flink简介 1.1 什么是Apache Flink&#xff1f; 1.2 Flink的核心组件 2. Java与Scala在Flink开发中的比较 2.1 语言特性对比 2.2 开发体验对比 3. 实际开发中的应用 3.1 使用Java进行Flink开发 3.2 使用Scala进行Flink开发 4. 关键性能和优化 4.1 性能对比 …...

C++STL专题 vector底层实现

目录 一&#xff0c; vector的手搓 1.构造函数 2. 拷贝构造的实现 3.析构函数 4.begin() end() 的实现 5.reserve的实现 6.size和capacity的实现 7.push_back的实现 8.pop_back的实现 9.empty的实现 10.insert的实现 11.erase的实现 12.resize的实现 13.clear的实…...

【Linux】装机常用配置

文章目录 1. 下载常用软件包2. 更新yum源3. vim编辑器配置4. 安装C语言和C的静态库&#xff08;换root&#xff09;5. git6. sudo给普通用户提权7. 更新git版本&#xff08;centos默认安装1.8.x&#xff0c;我们更新到2.x&#xff09;8. getch9. json10. 升级gcc版本11. 跨系统…...

oracle库PASSWORD_VERSIONS 对应的加密方式

oracle库PASSWORD_VERSIONS 对应的加密方式 10G DES 11G SHA-1 12C SHA-2-based SHA-512官方文档&#xff1a; https://docs.oracle.com/database/121/DBSEG/authentication.htm#DBSEG487...

分享一个基于微信小程序的乡村医疗上门服务预约平台(源码、调试、LW、开题、PPT)

&#x1f495;&#x1f495;作者&#xff1a;计算机源码社 &#x1f495;&#x1f495;个人简介&#xff1a;本人 八年开发经验&#xff0c;擅长Java、Python、PHP、.NET、Node.js、Android、微信小程序、爬虫、大数据、机器学习等&#xff0c;大家有这一块的问题可以一起交流&…...

切香肠(Sausage)

题目描述 有 n 条香肠&#xff0c;每条香肠的长度相等。我们打算将这些香肠切开后分给 k 名客人&#xff0c;且要求每名客人获得一样多的香肠&#xff0c;且要将所有的香肠分配完&#xff0c;不做保留。 请问最少需要切几刀才能完成&#xff1f;一刀只能切断一条香肠&#xf…...

Session与Cookie以及Cache区别,及应用场景

Session、Cookie和Cache是Web开发中常用的数据存储方式&#xff0c;它们在功能、存储位置和应用场景上有所不同。 一、Session、Cookie和Cache的区别 Session 存储位置&#xff1a;服务器端。功能&#xff1a;通过在服务器上存储唯一的标识符&#xff08;Session ID&#xff…...

Debian | 更换 Gnome 至 Xfce4

Debian | 更换 Gnome 至 Xfce4 更新源 sudo apt update && sudo apt upgrade安装 xfce4 sudo apt install xfce4我选择 lightdm&#xff0c;回车 切换桌面 sudo update-alternatives --config x-session-manager输入 xfce 所在序号&#xff0c;我这里是 3 卸载 …...

Windows Defender终极移除指南:高效释放系统资源的13项完整方案

Windows Defender终极移除指南&#xff1a;高效释放系统资源的13项完整方案 【免费下载链接】windows-defender-remover A tool which is uses to remove Windows Defender in Windows 8.x, Windows 10 (every version) and Windows 11. 项目地址: https://gitcode.com/gh_mi…...

衣柜里的暖,是藏不住的牵挂

老李独居在老房子里&#xff0c;儿女都在外地打拼&#xff0c;一年到头难得回几次家&#xff0c;平日里冷冷清清的屋子&#xff0c;只有逢年过节才会热闹几分。 北方的冬天总是格外漫长&#xff0c;寒风一吹&#xff0c;窗户缝里都透着刺骨的凉&#xff0c;老李年纪大了&#x…...

FPGA等精度频率计设计与实现

1. 等精度频率计的核心原理 等精度频率测量法之所以在FPGA设计中备受青睐&#xff0c;关键在于它巧妙地规避了传统方法的测量盲区。想象一下用两种不同的秒表测量短跑成绩&#xff1a;一个秒表由裁判手动控制&#xff08;软件闸门&#xff09;&#xff0c;另一个由运动员冲线瞬…...

QHotkey:跨平台全局快捷键解决方案架构与实践指南

QHotkey&#xff1a;跨平台全局快捷键解决方案架构与实践指南 【免费下载链接】QHotkey A global shortcut/hotkey for Desktop Qt-Applications 项目地址: https://gitcode.com/gh_mirrors/qh/QHotkey QHotkey是一个专为Qt桌面应用程序设计的全局快捷键管理工具&#x…...

内置“龙虾”的异地组网路由器!蒲公英X1 Pro重磅升级

蒲公英异地组网路由器X1 Pro重磅升级&#xff01;首款内置“龙虾”的路由器来了&#xff01;无需云服务器、无需额外电脑&#xff0c;在小巧的路由器里就能一键部署OrayClaw&#xff0c;拥有你的专属“龙虾”&#xff01;它不仅仅是个会聊天的AI&#xff0c;在支持随心搭配大模…...

开源许可证变更风波:商业与自由的博弈

在当今软件开发的生态系统中&#xff0c;开源软件已成为测试工作的核心支柱。从自动化框架到持续集成工具&#xff0c;测试从业者依赖开源组件提升效率与覆盖度。然而&#xff0c;近期开源许可证的频繁变更——如Redis从BSD转向RSALv2/SSPLv1、Bun 2.0从MIT切换到AGPLv3——正掀…...

ADXL345 I²C驱动开发:寄存器配置、FIFO与中断实战指南

1. ADXL345_I2C库深度解析&#xff1a;面向嵌入式工程师的IC加速度计驱动开发指南ADXL345是Analog Devices公司推出的超低功耗、高分辨率&#xff08;13位&#xff09;、数字输出三轴加速度传感器&#xff0c;广泛应用于姿态检测、振动监测、跌倒报警、工业预测性维护等场景。其…...

源码级交付的低代码革命:基于 Spring Boot 的 AI 视频中台二次开发实战

引言&#xff1a;从“项目定制”到“产品化”的跨越之痛 作为一名在安防行业摸爬滚打多年的架构师&#xff0c;我深知行业内的一个悖论&#xff1a;客户想要的是“开箱即用”的成熟产品&#xff0c;而现实场景却要求“千企千面”的深度定制。传统的开发模式下&#xff0c;为了满…...

IC670PBI001总线接口单元

IC670PBI001 是 GE Fanuc Field Control 系列中的一款 Profibus 总线接口单元&#xff08;BIU&#xff09;&#xff0c;主要用于连接PLC与远程I/O模块&#xff0c;实现数据通信与系统控制&#xff0c;是分布式I/O系统中的核心组件。1、作为系统核心接口单元&#xff0c;实现PLC…...

Mac上使用Docker快速部署SQL Server指南

1. 为什么要在Mac上通过Docker运行SQL Server&#xff1f; 作为常年使用Mac的开发者&#xff0c;我最初也很困惑&#xff1a;微软的SQL Server明明是为Windows设计的&#xff0c;为什么要在macOS上折腾&#xff1f;直到接手了一个使用SQL Server作为数据库的老项目才明白——当…...