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

MyBatis入门如何使用操作数据库及常见错误(yml配置)

一,什么是MyBatis

是一款优秀的持久层框架,用于简化jdbc的开发

持久层:指的就是持久化操作的层,通常也就是数据访问层(dao),也就是用来操作数据库。

也就是MyBatis是让你更加简单完成程序与数据库的交互,也就是更加简单的读取和操作数据库。

二,MyBatis入门

操作数据库步骤:

创建spring boot工程,数据库准备好

引入MyBatis相关依赖。

编写SQL语句

2.1项目创建

跟之前创建的步骤一样,但选择配置文件的时候,选择这两个,导⼊mybatis的起步依赖、mysql的驱动包

 

 这样在创建完成之后,会在pom文件中自动导入依赖,就不用你关注了。

2.2数据准备

也就是在数据库中把自己要用到的数据准备上,也就是MySQL的使用。

输入数据之后再配置相应的yml来调用数据库,代码如下:

spring:datasource:url: jdbc:mysql://127.0.0.1:3306/java_blog_spring?characterEncoding=utf8&useSSL=falseusername: rootpassword: 20030218driver-class-name: com.mysql.cj.jdbc.Driver
mybatis:configuration:map-underscore-to-camel-case: true #配置驼峰⾃动转换log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #打印sql语句mapper-locations: classpath:mapper/**Mapper.xml#设置⽇志⽂件的⽂件名
logging:file:name: spring-blog.log

注意要修改成自己的密码哦。

三,操作数据库时容易发生的错误

1.SQL语句错误

2.配置信息错误(一般是密码问题)

 3.url错误(未配置数据库)

4.数据库不存在(检查数据库与url数据库名是否一致)

 5.表不存在

6.方法名重复(会调用失败)

 四,CRUD(注解方法实现)

1.增

2.删

3.改

 4.查

5.#和$的区别

1.sql注入问题,$可以被注入,有风险。

注入原因:

# 进行预编译sql,采用占位的方式。

$ 直接拼接,有被注入的风险

2.#比$性能更高一点,想用的时候取出来就行了。

3.排序功能#不能实现,只能$来。 

 五,CRUD(xml实现)

配置xml,上面的yml文件中已经有xml基础了,直接创建xml进入配置:

1.增

 2.删

3.改

 4.查

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 删除链表的倒数第N个结点(LeetCode)
  • java中的tcp
  • SpringBoot集成GraalVM创建高性能原生镜像
  • 60个常见的 Linux 指令
  • 淘宝的商品信息缓存体系是如何构建的?
  • 基于多种机器学习的豆瓣电影评分预测与多维度可视化【可加系统】
  • 孟德尔随机化、R语言,报错,如何解决?
  • 【达梦数据库】通过线程pid定位会话SQL
  • Python——继承
  • vue2学习 -- 核心语法
  • 2024下半年,前端的技术风口来了
  • 【保姆级讲解下QT6.3】
  • JavaScript 实现通话计时(时分秒 本示例在uniapp中)
  • 2024小卷Spring Boot3.0教程思维导图整理
  • python np.max怎么用
  • 【跃迁之路】【444天】程序员高效学习方法论探索系列(实验阶段201-2018.04.25)...
  • chrome扩展demo1-小时钟
  • CSS3 聊天气泡框以及 inherit、currentColor 关键字
  • CSS进阶篇--用CSS开启硬件加速来提高网站性能
  • extract-text-webpack-plugin用法
  • Javascript设计模式学习之Observer(观察者)模式
  • JavaScript设计模式之工厂模式
  • Java反射-动态类加载和重新加载
  • js对象的深浅拷贝
  • js中forEach回调同异步问题
  • Puppeteer:浏览器控制器
  • scrapy学习之路4(itemloder的使用)
  • vue数据传递--我有特殊的实现技巧
  • 闭包,sync使用细节
  • 普通函数和构造函数的区别
  • 前端临床手札——文件上传
  • 使用API自动生成工具优化前端工作流
  • 小程序button引导用户授权
  • Mac 上flink的安装与启动
  • 宾利慕尚创始人典藏版国内首秀,2025年前实现全系车型电动化 | 2019上海车展 ...
  • # 职场生活之道:善于团结
  • ######## golang各章节终篇索引 ########
  • (03)光刻——半导体电路的绘制
  • (4)STL算法之比较
  • (4)通过调用hadoop的java api实现本地文件上传到hadoop文件系统上
  • (pojstep1.1.2)2654(直叙式模拟)
  • (笔试题)合法字符串
  • (二)JAVA使用POI操作excel
  • (二十三)Flask之高频面试点
  • (附源码)springboot太原学院贫困生申请管理系统 毕业设计 101517
  • (黑马出品_高级篇_01)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式
  • (每日一问)设计模式:设计模式的原则与分类——如何提升代码质量?
  • (四)事件系统
  • (转)http-server应用
  • .mat 文件的加载与创建 矩阵变图像? ∈ Matlab 使用笔记
  • .md即markdown文件的基本常用编写语法
  • .net 4.0发布后不能正常显示图片问题
  • .NET 8 中引入新的 IHostedLifecycleService 接口 实现定时任务
  • .Net mvc总结
  • .NET Project Open Day(2011.11.13)