欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 国际 > 数据库Mybatis基础操作

数据库Mybatis基础操作

2025/9/24 21:13:13 来源:https://blog.csdn.net/chencxiaobai/article/details/141374039  浏览:    关键词:数据库Mybatis基础操作

目录

基础操作

删除

预编译SQL

增、改、查

自动封装


基础操作

环境准备

删除

根据主键动态删除数据:使用了mybatis中的参数占位符#{ },里面是传进去的参数。

单元测试:

另外,这个方法是有返回值的,返回这次操作的数据数量,比如删除了一条记录,就返回1,以此类推。但一般没什么用,所以使用void不返回值。可以通过添加配置信息,输出mybatis的日志进行观察。

以下是mybatis的输出日志:?是参数占位符(替代了#{ }),传进参数(16),这里实际上并没有16这条数据,因此操作数据的数量updatas为0。

这条SQL语句叫做预编译SQL,那为什么不直接将16拼接在sql语句中呢?

预编译SQL

因为采用预编译SQL有两大优势:

  1. 性能提升:预编译SQL语句在第一次执行时会被编译,之后如果再次使用相同的SQL语句,就不需要重新编译,可以直接执行,这可以显著提高执行效率。

  2. 安全性增强:使用预编译SQL可以有效防止SQL注入攻击,因为SQL语句和参数是分开处理的。参数在执行时被传递给预编译的语句,而不是作为SQL语句的一部分,这样可以避免恶意用户通过修改参数来执行非法SQL操作。

SQL注入是通过操作输入的数据来修改事先定义好的SQL语句,以达到执行代码对服务器进行攻击的方法。以下为例子:

实际上,登录功能的账户密码校验就是查询操作,查询数据库中是否有账号和密码的数据存在,如果都存在就可以登录,如果不存在就返回错误信息。

存在账号张无忌zhangwuji并且密码为111,可以登录,反之就不能登录。

神奇的是以下的账号是随便输入的,但密码需要刻意写成这种形式。也可以成功登录

因为这段密码把sql语句的语义改写了,此时登录只需要‘1’=‘1’,而这是始终成立的。如下:

这种拼接的形式就有可能导致被SQL注入,因此就要采用预编译传参的形式进行规避。

参数占位符的区别:(面试题:#和$的占位符区别)

增、改、查

和删除一模一样,只是需要传递的参数太多,而这些参数都封装在Emp对象中,直接传递这个对象就行了。该方法也有返回值,和删除一样,就void不返回即可。

主键返回:在数据添加成功后,如果需要立即获取插入这条数据的主键,需要添加@options注解

更新:

数据一般不会更新主键,因此我们根据主键去修改数据。尾部增加一个id条件,对这个id的数据进行修改,其他的和删除新增一样。

查询:

同样根据id查询员工

条件查询:这里用了like模糊搜索和concat函数进行字符拼接,以避免SQL注入。

自动封装

绿色部分会自动封装到emp对象,而红色不能自动封装

三个解决方法:

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词