MyBatis案例--环境准备

1、依据之前在Navicat建立数据表的方法,新建立一个数据表

2、将数据表的相关内容表现在Java文件的实例上:即成员变量和set、get成员方法

3、new一个测试Java文件的Test.Java文件

4、安装MyBatis插件

能够较为方便地查看SQL映射文件下的statement对应的核心配置文件地位置

查询操作

1、编写接口方法:定义一个名称为:(BrandMapper)的接口

同之前操作相同,同时需要new一个.xml文件,与接口同名

2、编写SQL依语句,执行方法:写一个测试用例

步骤

1、获取SqlSessionFactory对象

2、获取SqlSession对象

3、获取Mapper接口的代理对象

4、执行方法

5、释放资源

查询所有:select * from 表名;

若是实体类属性名和数据库表列名不一致,不能自动封装数据

1、起别名

2、resultMap

查询部分:

1、 select 相应列名(可以使用起类型别名的方法进行查询)from 表名;----每次查询都要定义一次别名

2、使用将类型别名封装到一个sql里面,可以重复、多次使用;----但不灵活

再在select里面引用

3、使用----映射

---放置不一样的名称

并将select中的resultType更改为:resultMap="",中间放置id名称

查询--查看详情

举例:----参数占位符:#{} ${}

在查询所有的基础上,后面添加一个where id=#{id};

#{}:会将其替换为?,为了防止SQL注入---------使用时机:参数传递的时候

${}:会存在SQL注入的问题----------使用时机:表明或者列名不固定的情况下

参数类型:

parameterType:可以省略---用来设置参数类型

特殊字符处理:

1、转义字符---适用于特殊字符较少时

2、CDATA区---适用于特殊字符较多时(CD-->回车-->在其中填入特殊字符即可)

查询--条件查询

多条件查询

where 条件 and 条件 and 条件

三种方式接受参数:

使用=表示准确查询,而使用like,则表示模糊查询

1、散装参数

模糊查询,需要在参数两端加上对应的%,实现模糊查询;

2、对象参数

需要用set方法封装对象,举例:

Brand brand=new Brand();
brand.setStatus("status");
brand.setCompanyName("companyName");
brand.setBrandName("brandName");

3、map集合

需要用到HashMap封装对象,举例:

Map map=new HashMap();
map.put("status");
map.put("companyName");
map.put("brandName");

查询--多条件--动态条件查询

是对多条件查询的优化,实现了不一定要输入全部条件时才能查询到相关信息的功能,提高了查询的灵活性;

where

列名1=#{列名1}

若是定义的第一个条件存在,可以实现该动态查询

但是,若是定义的第一个条件不存在,where后面会直接显示and连接符,查询出现漏洞;

解决方法

1、恒等式:在第一个if选择之前加上一个恒等式,将之前定义的第一个if语句前面加上and连接符,即可解决!

2、用将if语句包含起来,即可解决!

单条件---动态条件查询



where后面添加一个标签,再在里面添加几个标签,即可实现单条件动态查询

但存在特殊情况,若是用户并未选择标签,直接选择查询,会直接报错!这个问题需要解决!

解决方法

恒等式:

在中将封装进去,里面放置一个恒等式,即可解决问题!

Javaweb学习笔记第九弹的更多相关文章

  1. JavaWeb学习笔记总结 目录篇

    JavaWeb学习笔记一: XML解析 JavaWeb学习笔记二 Http协议和Tomcat服务器 JavaWeb学习笔记三 Servlet JavaWeb学习笔记四 request&resp ...

  2. 交换机安全学习笔记 第九~十章 HSRP VRRP

    HSRP  (Hot Standby Router Protocol) 热备份路由器协议 思科私有 HSRP消息使用UDP 端口号 1985(IPv6时为2029) 使用多播地址 224.0.0.2( ...

  3. javaweb学习笔记整理补课

    javaweb学习笔记整理补课 * JavaWeb: * 使用Java语言开发基于互联网的项目 * 软件架构: 1. C/S: Client/Server 客户端/服务器端 * 在用户本地有一个客户端 ...

  4. 【JAVAWEB学习笔记】06_jQuery基础

    接05的学习笔记. 四.使用JQ完成省市二级联动 1.需求分析 使用jquery完成省市二级联动 2.技术分析 2.1数组的遍历操作 方式一: $(function(){ // 全选/ 全不选 $(& ...

  5. MyCat 学习笔记 第九篇.数据分片 之 数值分布

    1 应用场景 Mycat 自带了多套数据分片的机制,其实根据数值分片也是比较简单,其实这个和数据取摸是类似的实现. 优.缺点同上一篇 2 环境说明 参考  <MyCat 学习笔记>第六篇. ...

  6. 《机器学习实战》学习笔记第九章 —— 决策树之CART算法

    相关博文: <机器学习实战>学习笔记第三章 —— 决策树 主要内容: 一.CART算法简介 二.分类树 三.回归树 四.构建回归树 五.回归树的剪枝 六.模型树 七.树回归与标准回归的比较 ...

  7. javaweb学习笔记(二)

    一.javaweb学习是所需要的细节 1.Cookie的注意点 ① Cookie一旦创建,它的名称就不能更改,Cookie的值可以为任意值,创建后允许被修改. ② 关于Cookie中的setMaxAg ...

  8. Javaweb学习笔记(一)

    一.javaweb学习是所需要的细节 1.发送响应头相关的方法 1).addHeader()与setHeader()都是设置HTTP协议的响应头字段,区别是addHeader()方法可以增加同名的响应 ...

  9. 【JAVAWEB学习笔记】05_jQuery基础

    晨读单词: toggle:切换 each:每个(遍历) append:追加(内部追加,将B追加到A的内部结尾处) appendTo:追加(内部追加,将A追加到B的内部结尾处) prepend:追加(内 ...

  10. 《Python基础教程(第二版)》学习笔记 -> 第九章 魔法方法、属性和迭代器

    准备工作 >>> class NewStyle(object): more_code_here >>> class OldStyle: more_code_here ...

随机推荐

  1. Vmware 虚拟机Ubuntu系统,解决忘记用户名和密码解决办法

    1.在开机界面按住shift,会加载grub的启动界面,找到Advaced options for Ubuntu选项.按"e" 进入编辑模式. 2.光标移动至ro,改为rw,(Li ...

  2. Localstorage、sessionStorage、cookie 的区别

    共同点:都是保存在浏览器端.且同源的 区别: 1.cookie 数据始终在同源的 http 请求中携带(即使不需要),即 cookie 在浏览器和服务器 间来回传递,而 sessionStorage ...

  3. 学习lua-04,json.util merge方法对集合处理的实际应用,及tostring方法

    local jsonutil = require("json.util") local merge = require("json.util").merge l ...

  4. ssr next 学习记录

    预加载页面   只有生产环境才有 当页面初始化加载时,getInitialProps只会加载在服务端.只有当路由跳转(Link组件跳转或 API 方法跳转)时,客户端才会执行getInitialPro ...

  5. memoの颜色配置

    Visual Studio的配置 没啥说的,直接上网站: https://studiostyl.es/schemes/create 顺便保存一份我的配置 一些有趣的插件:Amigo 主题配色,还是Bl ...

  6. 关于webdriver和谷歌浏览器的那些事

    早上看了一个视频,讲述爬虫的,首先一开始就写了一行这样代码(如下): from selenium import webdriver # 创建浏览器对象 ,这会在电脑中打开浏览器窗口browser = ...

  7. 样式优先级的规则:!important`>行内样式>嵌入样式>外链样式>id选择器>类选择器>标签选择器>复合选择器>通配符>继承样式

    CSS样式的优先级应该分成四大类 第一类`!important`,无论引入方式是什么,选择器是什么,它的优先级都是最高的. 第二类引入方式,行内样式的优先级要高于嵌入和外链,嵌入和外链如果使用的选择器 ...

  8. cin和缓存区问题

    稍微记录一下今天刷题遇到的C++问题 看到使用while(cin >> s);来读取最后一个字符串.百度了一下发现cin以空格,制表符和回车为终止依据.也就是说我输入"abc 1 ...

  9. GitLab版本定版

    定版指令: git add -Agit commit -m ""git push origin develops:V5.2

  10. django前后端分离接口开发

    用django进行接口开发 接口: /api/parameter (同一个接口地址实现不同的请求方式) 全局参数(get,post,put,delete) GET:获取全局参数的所有数据 POST:创 ...