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

网站建设的费用预算昆山 网站设计

网站建设的费用预算,昆山 网站设计,自己可以做一个网站吗,网页设计网站哪个公司好MyBatis 为啥MyBatis会使用xml 在一个程序中,若需要操作数据表,那么 SQL 语句有两种存放方式:1. 放到 Java 类里面(这个就存在大量的字符串拼接,还有占位符需要处理-----JDBC);2:放…

MyBatis

为啥MyBatis会使用xml

在一个程序中,若需要操作数据表,那么 SQL 语句有两种存放方式:1. 放到 Java 类里面(这个就存在大量的字符串拼接,还有占位符需要处理-----JDBC);2:放到 xml 中(但是 xml 无法被 Java 代码调用的,所以就在 Java代码和 xml 中加了一层 对xml中方法的接口声明)

image-20230201102331856

MyBatis的基本使用

MyBatis 就是一个ORM(对象关系映射)框架,将数据库中的每张表映射成Java中的类,以此可以使用OOP思想来操作数据表了

程序启动时,@Mapper注解会根据配置文件里配置的mybatis路径+命名来讲接口与xml文件进行关联,并将@Mapper注解修饰的接口放入Spring中

配置数据库连接 + MyBatis 的 xml 存放路径 + 命名格式(xml中存放的就是数据表的操作语句)

image-20230115144955108

@Mapper

@Mapper注解比较特殊,虽然是修饰接口的,但是也能将其放入Spring中,然后使用@Autowired进行注入,并直接当作对象来调用其中的方法

image-20230201133703826

查询

  1. 创建一个接口

    image-20230201103355657

  2. 新建一个 xml 文件,来实现接口中的方法

    image-20230201104340105

带参数查询

image-20230201134800624

添加

默认返回受影响的行数,若需要返回自增主键的ID,需要给 Insert 设置参数 useGeneratedKeys=“true” keyProperty=“id”;将会把自增主键的值放入id列,直接对象的 getId 即可拿到

image-20230201152237037

image-20230201152246021

删除

image-20230201153629458

修改

image-20230201154448489

参数传递中#{} 与 ${}的区别

  • #{}:预编译处理(MyBatis 在处理 #{} 的时候,会将其替换为 ? ,底层还是使用 PrepareStatement 的 set 方法进行填充的)

  • ${}:直接替换(在判断字符串的时候,就会出问题,除非自己手动添加 引号)这个可以用在参数为关键字的时候,如:线上购物的时候,可以选择价格由低到高,由高到低;这个就需要传递 SQL 关键字了,desc / asc;就可以采用这种方式

    image-20230202102809273

SQL注入问题

${} 就存在 SQL 注入问题,它是直接 数值替换的

#{} 就不会存在SQL注入问题,它采用的就是 占位符的方式

image-20230202133715758

image-20230202133830202

like模糊查询

使用 MySQL 内置函数 concat

image-20230214152920290

resultMap

当数据表中的字段名与 类 中的属性名不同时,可以用 resultMap标签来进行映射(只要有一个字段不同,那么所有的字段都需要写,不然多表查询会存在问题)

image-20230202135632869

多表查询

一个讨巧的办法:在一个主要的实体类中,加另外需要的属性名

如下:显示文章表的所有信息(uid 是一个外键,表示用户表的id),需要讲 作者名字 显示出来

image-20230202141619405

动态SQL

主要用于处理表单的必填和选填的时候

当前端没有传递参数的时候,对应的字段就不应该插入值,这就可以用动态SQL来解决了(不需要写多条SQL语句,根据不同的情况调用不同的SQL语句,动态SQl一条语句解决全部的情况)

image-20230214153847474

if 标签

用作某个字段是否拼接上

trim标签

参数:prefix 前缀(语句最前面加的东西) suffix 后缀(语句最后面加的东西)

​ prefixOverrides(将最前面包含的东西去掉) suffixOverrides(将最后面包含的东西去掉)

image-20230214155950459

where标签

在指定字段进行筛选的时候,就可以用where标签(如:若输入了姓名来查就表示需要where条件;什么都没有输入的情况下,就表示查询所有,就不要where条件)虽然直接加where 1 = 1也可以解决,但并不直观

where 标签默认会去掉筛选条件最前面的 and

image-20230214161256861

相当于 标签

image-20230214161551274

set 标签

主要用于 update 语句中

作用:

  1. 添加 set 关键字
  2. 去掉最后一个逗号

image-20230214162001979

foreach标签

为了处理批量删除的情况,如果前端传过来的是一个集合,需要进行批量操作,就用foreach

collections 就是 接口中的参数名 separator 就是分隔符

item 就是遍历的当前对象 就相当于把 list 构造成:(1,2,3)的形式

进行批量操作,就用foreach

collections 就是 接口中的参数名 separator 就是分隔符

item 就是遍历的当前对象 就相当于把 list 构造成:(1,2,3)的形式

image-20230214163628632

http://www.yayakq.cn/news/85011/

相关文章:

  • 坑梓网站建设网站全网建设莱芜
  • 如何创立自己的网站wordpress安装详细教程
  • 网站改版换了域名爱站工具包
  • 电子商务网站建设及管理seo营销论文
  • 沭阳网站建设招聘个人网页设计思路
  • 织梦商业网站内容管理系统做音乐网站的条件
  • 模具做外贸网站湖南建筑信息网官网
  • 做一个网站的费用构成适合vue做的网站类型
  • 营销策划的重要性郑州网站优化方案
  • 网站导航设计原则免费wordpress云服务
  • 建设网站及后期维护费用是多少网站开发仓库管理系统需求分析
  • 昆明专业做网站好点的网站建设公司
  • 做网站吗wordpress模板 charset
  • 重庆网站seo优化网站建设中网站需求分析和报告工能论文
  • 网络推广运营外包网站建立网络优化
  • 网站数据修改设计页面宽度
  • 谷城网站建设做网站赚钱有哪些途径
  • 网站建设seo视频高级搜索入口
  • 商城网站设计wordpress降低版本
  • 网站的开发环境seo黑帽技术
  • 自己想做一个网站怎么做企业信息公开网查询
  • 网站开发文档包括有名的室内设计公司
  • 网站全屏轮播代码品牌建设与质量培训
  • 天津交通网站建设网页设计相关的网站
  • 那个网站可以做家具效果图国外室内设计网站排名
  • 网站模板是指网站内容的总体结构和页面格式总体规划网站开发推进计划表
  • 怎么查网站是谁建的成都公司网站设计哪家专业
  • mixkitcom素材网站衡阳商城网站制作
  • 神木网站建设当今做哪些网站能致富
  • 重庆网站seo建设百度seo排名推广