prepareStatement语句

prepareStatement语句JDBC中的——PreparedStatement预编译原理prepareStatement语句有三大好处:Statement.executeUpdate(“INSERTINTOtb1_students(name,age,sex,address)VALUES(‘”+var1+”‘,'”+var2+”‘,”+var3+”,'”+var4+”‘)”);​prepareStatement=connection.prepareStatement(“INSERTINTOtb1_stud

大家好,又见面了,我是你们的朋友全栈君。

JDBC中的——PreparedStatement 预编译原理

prepareStatement语句有三大好处:

Statement.executeUpdate("INSERT INTO tb1_students (name,age,sex,address) VALUES('"+var1+"','"+var2+"',"+var3+",'"+var4+"')"); 
​
prepareStatement= connection.prepareStatement("INSERT INTO tb1_students (name,age,sex,address) VALUES (?,?,?,?)"); 
prepareStatement.setString(1,var1); 
prepareStatement.setString(2,var2); 
prepareStatement.setString(3,var3); 
prepareStatement.setString(4,var4); 
prepareStatement.executeUpdate(); 

1、提高了代码的可读性和可维护性

很明显可以看出,第一种语句很繁琐,没有第二种语句简单明了,虽然代码是多了几行,但从代码的可读性和可维护性上来看,第二种优于第一种。

2、PreparedStatement尽最大可能提高性能

每一种数据库都会尽最大努力对预编译语句提供最大的性能优化。因为预编译语句有可能被重复调用,所以语句在被数据库(DB)的编译器编译后的执行代码被缓存下来,那么下次调用时只要是相同的预编译语句就不需要编译,只要将参数直接传入编译过的语句执行代码中(相当于一个函数)就会得到执行。这并不是说只有一个Connection中多次执行的预编译语句被缓存,而是对于整个DB中,只要预编译的语句语法和缓存中匹配。那么在任何时候就可以不需要再次编译而可以直接执行,而在statement的语句中,即使是相同一操作,而由于每次操作的数据不同,所以使整个语句相匹配的机会极小,几乎不太可能匹配。比如:

INSERT INTO tb1_students (name,age) VALUES('LISI','18'); 
INSERT INTO tb1_students (name,age) VALUES('WANGER','32'); 

即使是相同操作,但因为数据内容不一样,所以整个语句本身不能匹配,没有缓存语句的意义。事实是没有数据库会对普通语句编译后的执行代码缓存,这样每执行一次都要对传入的语句编译一次。 当然并不是所有预编译语句都一定会被缓存,数据库本身会运用一种SQL语句优化策略,比如使用频度等因素来决定什么时候不再缓存已有的预编译结果。以保存有更多的空间存储新的预编译语句。

3、这是最重要的一点:极大地提高了安全性 即使到目前为止,仍有一些人连基本的恶义SQL语法都不知道。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135145.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月5日 下午6:16
下一篇 2022年6月5日 下午6:16


相关推荐

  • springcache清除缓存_什么叫做缓存数据

    springcache清除缓存_什么叫做缓存数据概述从spring3开始,spring开始支持缓存组件,并提供了一系列非常方便的注解。其中,Cache接口定义了基本的增删改查方法,Spring提供了一些默认的实现,比如RedisCa

    2022年8月16日
    9
  • Java刷新bean重新加载bean 上下文 刷新bean

    Java刷新bean重新加载bean 上下文 刷新bean@Autowiredprivate ApplicationContext applicationContext;// 可以为接口或者业务方法被调用public void reloadInstance(){ //获取上下文 DefaultListableBeanFactory defaultListableBeanFactory = (DefaultListableBeanFactory)applicationContext.getAutowireCapableBeanFactory();

    2022年8月19日
    19
  • android toast居中显示_Android Toast 设置到屏幕中间以及其他自定义Toast的实现方法…

    android toast居中显示_Android Toast 设置到屏幕中间以及其他自定义Toast的实现方法…AndroidToast 用于在手机屏幕上向用户显示一条信息 一段时间后信息会自动消失 信息可以是简单的文本 也可以是复杂的图片及其他内容 显示一个 view 1 简单用法 Toast makeText midlet getApplicati 用户名不能为空 Toast LENGTH LONG show 2 自定义显示位置效果代码 toast Toast mak

    2026年3月17日
    2
  • tkmapper mybatis plus 集成_gitea docker

    tkmapper mybatis plus 集成_gitea docker———————————————————————————————————————————-一、设置TkMapper单独放在一个包:这个包只有TkMapper一个文件importtk.mybatis.mapper.common.M…

    2022年10月7日
    6
  • python里for循环用法_python遍历循环

    python里for循环用法_python遍历循环python中使用for循环的方法发布时间:2020-12-0809:35:27来源:亿速云阅读:95作者:小新小编给大家分享一下python中使用for循环的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!python循环方式有两个,一个是while循环,另一个就是for循环,while循环和if条件分支语句类似,即在条件(表达式)为真的情况下,会执行相应的代码块。…

    2022年8月12日
    8
  • prefetch 和preload_使用 Preload/Prefetch 优化你的应用

    prefetch 和preload_使用 Preload/Prefetch 优化你的应用衡量网站的性能的指标有很多 其中有项重要的指标就是网站的首屏时间 为此前端工程师们都是绞尽脑汁想尽办法进行优化自己的应用 诸如像服务端渲染 懒加载 CDN 加速 ServiceWorke 等等方法 今天介绍的 preload prefetch 是一种简单 但却事半功倍的优化手段 基本用法在网络请求中 我们在使用到某些资源比如 图片 JS CSS 等等 在执行之前总需要等待资源的下载 如果我们能做

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号