陕西城乡建设局网站/网络优化需要哪些知识
目录
1.概述
2.mybatis搭建
1.创建一个maven项目,添加mybatis、mysql所依赖的jar
2.创建一个数据库表,及对应的java类
3.创建一个mybatis的核心配置文件,配置数据库连接信息,配置sql映射文件
4.创建sql映射文件,定义一个与接口方法名相同的查询语句
5.创建一个访问接口,定义一个方法
6.测试
API接口
SqlSessionFactory接口
SqlSession接口
嵌套查询
数据库连接池(缓冲池)
7.单元测试插件
8.参数传递
#{} 和${}区别
9.结果处理
1.简单类型输出映射
2.对象映射
3.特殊处理定义 resultMap
4.多表关联处理结果集
10.Mybatis 动态 SQL
if
where
trim
choose
set
foreach
11.特殊符号处理
12.mybatis一级缓存和二级缓存
一级缓存
二级缓存
1.概述
mybatis是一款优秀的持久层框架
mybatis是对jdbc功能进行轻量级的封装, 提供了统一的数据库信息配置,统一放在一个xml文件中,读取就行;
将sql提取到一个xml文件中, 提供了动态sql功能 提供了结果自动映射封装;
是一个orm(ORM Object Relational Mapping 对象关系映射)实现,orm指的是,将数居中的记录与java中的对象进行关系映, 对jdbc原生接口进行封装,提供了一些mybatis自己的接口和类来实现.
servlet(负责接收前端请求 调用其他的java程序处理 响应) web层
service(业务逻辑层) 验证数据 调用dao 结果 组装 服务层(逻辑处理,数据组装)
dao(data access Object) jdbc 数据持久层
2.mybatis搭建
1.创建一个maven项目,添加mybatis、mysql所依赖的jar
2.创建一个数据库表,及对应的java类
3.创建一个mybatis的核心配置文件,配置数据库连接信息,配置sql映射文件
4.创建sql映射文件,定义一个与接口方法名相同的查询语句
5.创建一个访问接口,定义一个方法
6.测试
读取配置
Reader reader = Resources.getResourceAsReader("mybatis-config.xml");
创建SqlSessionFactory
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder(
).build(reader);
创建SqlSession
SqlSession sqlSession = sessionFactory.openSession();
创建接口代理对象
sqlSession.getMapper(接口.class); sqlSession .close();
调用接口中的方法 执行对应的sql
API接口
SqlSessionFactory接口
SqlSessionFactory 用来创建SqlSession,只创建一次,一旦创建 ,SqlSessionFactory就在整个应用过程中存在。
SqlSession接口
SqlSession代表和数据库连接会话,此接口封装了对数据库的操作方法,完成后关闭会话
嵌套查询
将一个多表关联查询拆分为多次查询,先查询主表数据,然后查询关联表数据.
<resultMap id="studentMap" type="Student"><id column="id" property="id"></id><result column="num" property="num"></result><result column="name" property="name"></result><result column="gender" property="gender"></result><!--将学生关系和操作人信息分别封装到宿舍对象和管理员对象中去 属于嵌套--><association property="dorm" javaType="Dorm"><result column="dnum" property="num"></result></association><association property="admin" javaType="Admin"><result column="account" property="account"></result></association>
</resultMap>
<resultMap id="dormMap" type="Dorm"><id column="id" property="id"></id><result column="num" property="num"></result><collection property="students" javaType="list" ofType="Student"><result column="name" property="name"></result><result column="snum" property="num"></result></collection>
</resultMap>
数据库连接池(缓冲池)
现在每与数据库交互一次,创建一个数据库连接对象(Connection,Sql),用完就关闭销毁。下次需要,就重复此过程。问题:频繁创建销毁对象,开销大
思想:可以在启动时设置一个容器,在里面初始化好一些数据库连接对象,有请求到来时,可不用每次创建销毁,可重复使用,减少了频繁创建销毁链接对象的开销。
7.单元测试插件
使某一方法可以独立运行
@Testpublic void update() {SqlSession sqlSession= MybatisUtil.getSqlSession();StudentDao studentDao=sqlSession.getMapper(StudentDao.class);Student student=new Student();student.setId(1);student.setNum(107);student.setName("qq");studentDao.updateStudent(student);sqlSession.commit();sqlSession.close();}
8.参数传递
-
单参数直接传递,基本类型不需做任何处理
Admin findAdminById(int id);
-
多参数处理方式
Admin login(@Param("acc") String account,@Param("pwd") String password);
-
多参数封装到一个对象中
Admin login1(Admin admin);
#{} 和${}区别
-
#{参数名}
传值是预编译方式,更安全,主要用于向sql中传值
-
${参数名}
主要用来动态的向sql中传列名 传值时是直接将参数拼接到sql中(不建议) 排序 order by ${column} 动态传列名进来
9.结果处理
1.简单类型输出映射
返回简单基本类型 <select id="adminCount" resultType="int">SELECT COUNT(*) FROM admin </select>
2.对象映射
mybatis会将查询到的结构自动封装到一个对象中,会自己创建给定类型的对象 自动封装结果有条件:1.开启了全局的自动结果映射 PARTIAL 默认是单张表开启的2.数据库列名和属性名一样 如果名字不一致,不能映射,两种解决方法:(1)可设置别名使其映射(2)<setting name="mapUnderscoreToCamelCase" value="true"/>
3.特殊处理定义 resultMap
1.resultMap 的 id 是resultMap 的唯一标识
2.column 是映射查询结果的列名称
property 是类中的属性名称
<resultMap id="adminMap" type="Admin"><id column="id" property="id"></id><!--封装映射主键列--><result column="admin_gender" property="gender"></result>
</resultMap>
<select id="findAdmins1" resultMap="adminMap">select id,account,password,admin_gender from admin
</select>
4.多表关联处理结果集
注解标签
@Insert : 插入 sql
@Select :查询 sql
@Update :更新 sql
@Delete :删除 sql
@Results :设置结果集合
@Result : 结果
比如:
@Delete("delete from student where id=#{id}")void deleteStudent(int id);@Insert("insert into student(num,name,gender)value (#{num},#{name},#{gender})")void saveStudent(Student student);@Select("select * from student where id=#{id}")@Results(id="stumap",value={@Result(id = true,column = "id",property = "id"),@Result(column = "num",property = "num")})@ResultMap(value = "stumap")Student findStudent(int id);
10.Mybatis 动态 SQL
MyBatis 中用于实现动态 SQL 的元素主要有:
If、 where、 trim、 set、 choose (when, otherwise)、 foreach
if
对传入的条件进行判断
where
where 动态根据where标签内的if是否有成立,动态添加where关键宁,还可以去除条件前面的关键宁(anc/ or)
当查询条件的个数不确定时,使用where标签,当标签中有返回值时,就会插入一个我where;
若标签返回的内容以and/or开头,where标签自动剔除and/or。
trim
当 WHERE 后紧随 AND 或则 OR 的 时候,就去除 AND 或者 OR。prefix 前缀,prefixOverrides 覆盖首部指定 内容
choose
choose\when\otherwise
多个条件选择一个,可有多个when
select id,num,name,gender from student<trim prefix="where" prefixOverrides="and"><choose><when test="num!=0">num=#{num}</when><when test="name!=null">and name=#{name}</when><otherwise>and gender=#{gender}</otherwise></choose></trim>
set
set可取去除最后一个逗号
foreach
open 表示该语句以什么开始(仅执行一次)
separator 表示在每次进行迭代之间以什么符号作为分隔符;
close 表示以什么结束(仅执行一次)
item 表示集合中每一个元素进行迭代时的别名;
index 表一个名字,表示在迭代过程中,每次迭代到的位置
collection
如果传入的是单参数且参数类型是一个 List 时,collection 属性值为 list
如果传入的是单参数且参数类型是一个 array 数组时,collection 的属性值为 array
<delete id="deleteStudent">delete from student where id in<foreach collection="list" item="item" open="(" separator="," close =")" >#{item}</foreach>
</delete>
11.特殊符号处理
xml属于标记语言,类似<、>、& 不能再sql中使用,mybatis会报错
解决办法
1.转义符号代替
特殊字符 转义字符
< &It
> >
" "
' &apos
& &
<delete id="deleteStudent">delete from student where id < 10<if test="id!=@ & id>10"></if>
</delete>
2.使用 <![CDATA[ < ]]> 进行处理,尽量只将特殊符号写在里面
<delete id="deleteStudent">delete from student where id <![CDATA[<]]> 10
</delete>
12.mybatis一级缓存和二级缓存
缓存(cache)的作用是为了减去数据库的压力,提高查询效率。缓存实现的原理是从数据库中查询出来的对象在使用完后不要销毁,而是存储在内存(缓存)中, 当再次需要获取该对象时,直接从内存(缓存)中直接获取,不再向数据库执行 select 语句,从而减少了对数据库的查询次数,因此提高了数据库的性能。
一级缓存
一级缓存的作用域是同一个 SqlSession, 在同一个 sqlSession 中两次执行相同的 sql 语句,第一次执行完毕会将数据库中查询的数据写到缓存(内存),第二次会从缓存中获取数据,不再从数据库查询,提高查询效率。当一个 sqlSession结束后该 sqlSession 中的一级缓存就销毁了。
Mybatis 默认开启一级缓存。
一级缓存失效(生命周期):
1. sqlsession.close(); 销毁sqlsession对象 2. sqlsession.clearCache(); 清楚缓存数据 3. 执行有关增删改操作会清除缓存数据
二级缓存
二级缓存是SqlSessionFactory级别(一个),若将查询到的数据放到二级缓存中,可实现多个 SqlSession 共享;
当第一次查询到数据后并且关闭Sqlsession时数据被存入到二级缓存中,
Mybatis 默认没有开启二级缓存需要配置开启:
1.在SqlMapperConfig.xml中启用:
<setting name="cacheEnabled" value="true"/>
2.在Mapper映射文件中启用:
<cache flushInterval="1000”></cache>
3.实现序列化接口:
将所有的 POJO 类实现序列化接口 Java.io. Serializable
相关文章:

mybatis概述及搭建
目录 1.概述 2.mybatis搭建 1.创建一个maven项目,添加mybatis、mysql所依赖的jar 2.创建一个数据库表,及对应的java类 3.创建一个mybatis的核心配置文件,配置数据库连接信息,配置sql映射文件 4.创建sql映射文件,…...

DNDC模型---土壤碳储量、温室气体排放、农田减排、土地变化、气候变化中的应用
由于全球变暖、大气中温室气体浓度逐年增加等问题的出现,“双碳”行动特别是碳中和已经在世界范围形成广泛影响。国家领导人在多次重要会议上讲到,要把“双碳”纳入经济社会发展和生态文明建设整体布局。同时,提到要把减污降碳协同增效作为促…...

Android studio 2022.3.1 鼠标移动时不显示快速文档
在使用技术工具的过程中,我们时常会遇到各种各样的问题和挑战。最近,我升级了我的Android Studio到2022.3.1版本,但是在使用过程中,我碰到了一个让我颇为困扰的问题:在鼠标移动到类名或字段上时,原本应该显…...
五度易链最新“产业大数据服务解决方案”亮相,打造数据引擎,构建智慧产业!
快来五度易链官网 点击网址【http://www.wdsk.net/】 看看我们都发布了哪些新功能!!! 自2015年布局产业大数据服务行业以来,“五度易链”作为全国产业大数据服务行业先锋企业,以“让数据引领决策,以智慧驾驭未来”为愿景,肩负“打…...

简述hive环境搭建
文章目录 部署参数配置hive简单命令 部署 Hive的三种部署模式,主要按Metastore 的运行模式进行区分。 在安装Hive之前,要求先预装JDK 8、Hadoop、MySQL ; 1.下载hive,并解压缩到用户主目录下 tar -xzvf apache-hive-2.3.6-bin.t…...

小米AI音箱联网升级折腾记录(解决配网失败+升级失败等问题)
小米AI音箱(一代)联网升级折腾记录 我折腾了半天终于勉强能进入下载升级包这步,算是成功一半吧… 总结就是,网络信号一定要好,需要不停换网找到兼容的网,还需要仔细配置DNS让音响连的上api.mina.mi.com 推荐…...

tensorRT安装
官方指导文档:Installation Guide :: NVIDIA Deep Learning TensorRT Documentation 适配很重要!!!! 需要cuda, cuDNN, tensorRT三者匹配。我的cuda11.3 所以对应的cuDNN和tensorRT下载的是如下版本: cud…...

电脑重装+提升网速
https://www.douyin.com/user/self?modal_id7147216653720341767&showTabfavorite_collectionhttps://www.douyin.com/user/self?modal_id7147216653720341767&showTabfavorite_collection 零封有哈数的主页 - 抖音 (douyin.com)https://www.douyin.com/user/self?…...

Modelica由入门到精通—为什么要学习Modelica语言
1.为什么要学习Modelica语言 本人正在研究Modelica 多领域统一建模仿真语言,特此做学习入门介绍,希望可以帮助需要的小伙伴。 文章目录 1.为什么要学习Modelica语言一、背景二、系统建模与仿真2.1 系统仿真与系统模型2.2 仿真价值与可靠性 三、物理建模…...

opencv 进阶20-随机森林示例
OpenCV中的随机森林是一种强大的机器学习算法,旨在解决分类和回归问题。随机森林使用多个决策树来进行预测,每个决策树都是由随机选择的样本和特征组成的。在分类问题中,随机森林通过投票来确定最终的类别;在回归问题中࿰…...

Spring Boot进阶(58):集成PostgreSQL数据库及实战使用 | 万字长文,超级详细
1. 前言🔥 PostgreSQL是一种广泛使用的开源关系型数据库,具有可靠性高、性能优异、拥有丰富的数据类型和扩展等优点,越来越多的企业和开发者开始使用它来存储和管理数据。而Spring Boot是一种快速开发的框架,可以简化开发过程并提…...

Java | 使用ServerSocket查找TCP可用端口
关注:CodingTechWork 引言 在项目开发中,有一个程序是专门给服务下发tcp端口占用的,但是tcp端口有时候会被其他服务给占用,此时端口就会冲突。本文提供一个工具类进行端口占用判断并返回可用端口。 代码 工具类 Slf4j public …...

【深入浅出C#】章节 9: C#高级主题:LINQ查询和表达式
C#高级主题涉及到更复杂、更灵活的编程概念和技术,能够让开发者更好地应对现代软件开发中的挑战。其中,LINQ查询和表达式是C#高级主题中的一项关键内容,具有以下重要性和优势: 数据处理和操作: 在现代软件中ÿ…...

【Git】git clone --depth 1 浅克隆
问题 PycharmProjects git clone git Cloning into risk-package... remote: Counting objects: 576, done. error: pack-objects died of signal 947/574) error: git upload-pack: git-pack-objects died with error. fatal: git upload-pack: aborting due to possible r…...

搭建 Gitlab
当设置和配置 GitLab 实例并执行诸如创建群组、项目、用户和上传代码等操作时,涉及到多个步骤,每个步骤都有特定的目的。让我们逐步解释每个步骤并说明其背后的原因: 安装必需的软件: yum install -y curl policycoreutils-python…...

CTFhub-sqli注入-报错注入
用到的函数 updatexml(1, ,1) concat(0x7e, ,0x7e) group_concat(目标值) right(,32) 1 1 1 union select updatexml(1,concat(0x7e,database(),0x7e),1) 1 union select updatexml(1,concat(0x7e,(select(group_concat(ta…...

中国人民大学与加拿大女王大学金融硕士让金融界短暂迷茫的你发现新的方向
此刻金融职场的你已经站在了金融金字塔的哪个层级?是正在金融界不断的改变自己,迎接着一个又一个的挑战成为了职场精英?还是转行的想法不断敲打着你,但是又不知道自己该干什么,能干什么,发现自己的职业核心…...

PHPEXCEL 导出excel
$styleArray [alignment > [horizontal > Alignment::HORIZONTAL_CENTER,vertical > Alignment::VERTICAL_CENTER],];$border_style [borders > [allborders > [style > \PHPExcel_Style_Border::BORDER_THIN ,//细边框]]];$begin_date $request->beg…...

Elasticsearch简介及安装
🍓 简介:java系列技术分享(👉持续更新中…🔥) 🍓 初衷:一起学习、一起进步、坚持不懈 🍓 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正🙏 🍓 希望这篇文章对你有所帮助,欢…...

Python 密码破解指南:10~14
协议:CC BY-NC-SA 4.0 译者:飞龙 本文来自【OpenDocCN 饱和式翻译计划】,采用译后编辑(MTPE)流程来尽可能提升效率。 收割 SB 的人会被 SB 们封神,试图唤醒 SB 的人是 SB 眼中的 SB。——SB 第三定律 十、加…...

Spring、SpringMVC、SpringBoot三者的区别
目录 Spring是什么? SpringMVC是什么? SpringBoot是什么? Spring、SpringMVC、SpringBoot三者之间的关系 Spring是什么? Spring是一个开源的应用程序框架,它提供了一种简易的开发方式,通过依赖注入和面…...

探索PDF校对:为何这是现代数字文档的关键步骤
在今日的数字化浪潮中,文档的创建与分享从未如此频繁。尤其是PDF,作为一个普遍接受的标准文件格式,其在企业、学术和日常生活中的应用已经无处不在。但随之而来的挑战是如何确保文档的准确性和专业性。让我们深入探索PDF校对的重要性以及它为…...

linux 同时kill杀死多进程实践
使用场景 当程序中有使用到多进程且进程数较多的情况,如下图,且需要通过控制台杀死所有的 GSM_run.py 的进程时,利用 kill 命令一个一个的去结束进程是及其耗时且繁琐的,这时就需要我们的kill多进程的命令工作了。 批量 Kill 进程…...

全流程R语言Meta分析核心技术
Meta分析是针对某一科研问题,根据明确的搜索策略、选择筛选文献标准、采用严格的评价方法,对来源不同的研究成果进行收集、合并及定量统计分析的方法,最早出现于“循证医学”,现已广泛应用于农林生态,资源环境等方面。…...

打家劫舍00
题目链接 打家劫舍 题目描述 注意点 如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警0 < nums[i] < 400 解答思路 最初想的是使用深度优先遍历,到达任意一个位置时,小偷想要偷窃最高金额,一定要选择后面第2个房…...

LeetCode解法汇总1267. 统计参与通信的服务器
目录链接: 力扣编程题-解法汇总_分享记录-CSDN博客 GitHub同步刷题项目: https://github.com/September26/java-algorithms 原题链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 描述: 这里有一幅…...

Go 语言在 Windows 上的安装及配置
1. Go语言的下载 Golang官网:All releases - The Go Programming Language Golang中文网:Go下载 - Go语言中文网 - Golang中文社区 两个网站打开的内容只有语言不同而已,网站上清晰的标注了不同操作系统需要对应安装哪个版本,其中…...

如何在不使用任何软件的情况下将 PDF 转换为 Excel
通常,您可能会遇到这样的情况:您需要的数据不在 Excel 工作表中,而是以数据表形式出现在 PDF 文件中。为了将此数据放入 Excel 工作表中,如果您尝试将数字复制并粘贴到电子表格中,则列/行将无法正确复制和对齐。因此&a…...

【C语言】动态内存管理(malloc,free,calloc,realloc)-- 详解
一、动态内存分配 定义:动态内存分配 (Dynamic Memory Allocation) 就是指在程序执行的过程中,动态地分配或者回收存储空间的分配内存的方法。动态内存分配不像数组等静态内存分配方法那样,需要预先分配存储空间,而是由系统根据程…...

adb 命令
1.adb shell dumpsys activity top | find "ACTIVITY" 查看当前运行的activity包名 2.adb shell am start -n 包名/页面名 打开应用的页面 3.查看将要启动或退出app的包名 adb shell am monitor 只有在启动或退出的时候才会打印 4.查看当前启动应用的包名 ad…...