位置: 编程技术 - 正文

MySQL预编译功能详解(mysql预编译原理)

编辑:rootadmin

推荐整理分享MySQL预编译功能详解(mysql预编译原理),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql预编译原理,预编译方式无法解决sql注入的安全问题,mysql 编译,预编译方式无法解决sql注入的安全问题,mysql预编译防止注入,mysql 预编译,mysql预编译防止注入,mysql预编译防止注入,内容如对您有帮助,希望把文章链接给更多的朋友!

本文为大家分享了MySQL预编译功能,供大家参考,具体内容如下

1、预编译的好处

  大家平时都使用过JDBC中的PreparedStatement接口,它有预编译功能。什么是预编译功能呢?它有什么好处呢?  当客户发送一条SQL语句给服务器后,服务器总是需要校验SQL语句的语法格式是否正确,然后把SQL语句编译成可执行的函数,最后才是执行SQL语句。其中校验语法,和编译所花的时间可能比执行SQL语句花的时间还要多。  如果我们需要执行多次insert语句,但只是每次插入的值不同,MySQL服务器也是需要每次都去校验SQL语句的语法格式,以及编译,这就浪费了太多的时间。如果使用预编译功能,那么只对SQL语句进行一次语法校验和编译,所以效率要高。

2、MySQL执行预编译

MySQL执行预编译分为如三步:执行预编译语句,例如:prepare myfun from 'select * from t_book where bid=&#;'设置变量,例如:set @str='b1'执行语句,例如:execute myfun using @str如果需要再次执行myfun,那么就不再需要第一步,即不需要再编译语句了:设置变量,例如:set @str='b2'执行语句,例如:execute myfun using @str通过查看MySQL日志可以看到执行的过程:

MySQL预编译功能详解(mysql预编译原理)

3、使用Statement执行预编译

使用Statement执行预编译就是把上面的SQL语句执行一次。

4、useServerPrepStmts参数

  默认使用PreparedStatement是不能执行预编译的,这需要在url中给出useServerPrepStmts=true参数(MySQL Server

4.1之前的版本是不支持预编译的,而Connector/J在5.0.5以后的版本,默认是没有开启预编译功能的)。

  例如:jdbc:  这样才能保证mysql驱动会先把SQL语句发送给服务器进行预编译,然后在执行executeQuery()时只是把参数发送给服务器。

5、cachePrepStmts参数

  当使用不同的PreparedStatement对象来执行相同的SQL语句时,还是会出现编译两次的现象,这是因为驱动没有缓存编译后的函数key,导致二次编译。如果希望缓存编译后函数的key,那么就要设置cachePrepStmts参数为true。例如:  jdbc:

几个比较重要的MySQL变量 MySQL变量很多,其中有一些MySQL变量非常值得我们注意,下面就为您介绍一些值得我们重点学习的MySQL变量,供您参考。1Threads_connected首先需要注意的,想

MySQL 声明变量及存储过程分析 声明变量设置全局变量set@a='一个新变量';在函数和储存过程中使用的变量decleardeclearaintunsigneddefault1;这种变量需要设置变量类型而且只存在在begin..end这

MySQL删除表数据的方法 在MySQL中有两种方法可以删除数据,一种是DELETE语句,另一种是TRUNCATETABLE语句。DELETE语句可以通过WHERE对要删除的记录进行选择。而使用TRUNCATETABLE将删

标签: mysql预编译原理

本文链接地址:https://www.jiuchutong.com/biancheng/348336.html 转载请保留说明!

上一篇:MySQL5.7 JSON类型使用详解(mysql jsonb)

下一篇:几个比较重要的MySQL变量(几个比较重要的家风)

  • 劳务派遣公司需要给员工缴纳社保吗
  • 契税印花税会计怎么做账务处理
  • 借款合同印花税税率2023
  • 财务工作中如何做好协同工作
  • 收购农副产品怎么做账
  • 一般纳税人外地预交税款怎么预缴
  • 物业公司一般纳税人增值税税率
  • 未能确认收入的原因
  • 小规模纳税人应交增值税怎么算
  • 包装纸箱属于原材料吗
  • 国外进口原材料会计处理
  • 私房装修费能在公司报销吗
  • 多交税款抵税会计分录
  • 加工原因造成的废品损失
  • 企业生产设备发生的日常维修费用
  • 小规模纳税人工资可以抵扣增值税吗
  • 待处理财产损益借方余额代表什么
  • 固定资产折旧属于制造费用吗
  • 车辆增值税抵扣多少点
  • 记账错误是什么意思
  • 金税盘怎么做账务处理
  • 投资性房地产房产税如何计算
  • 返聘人员如何缴纳个人所得税
  • 社保显示已申报,但缴不了款
  • 工程结算收入的会计分录
  • vivo手机可以安装鸿蒙
  • 净资产增加数怎么计算
  • 如何编制处置固定资产
  • 取得土地所有权范围内的树如何处理
  • u盘win10系统安装教程
  • 小微企业免征税额度
  • 工程投标保证金一般是多少
  • 房地产开发企业增值税怎么算
  • 缴住房公积金会计分录怎么写
  • kaggle如何入门
  • 房产备案交税
  • php socket_create
  • php封装app打包
  • vuepress plugin
  • 利息 记账
  • 小规模纳税人销售商品会计分录
  • 客户多付款不要了多这部分是哪种收入?
  • 收据的种类有哪些
  • 联营扣点怎么做账
  • 法人股东的分红怎么算
  • 以非现金资产抵偿债务
  • 短期借款的核算
  • 被盗物品损坏谁负责赔偿
  • 出口样品的销售好做吗
  • 印花税的征税对象有哪些
  • 非营利性组织和营利性组织的区别
  • 清算后剩余财产股东拒收怎么办
  • sql server 数据
  • mysql允许字段为空
  • mysql怎么把列变成行
  • windows9预览版下载
  • windowsserver2008远程桌面怎么打开
  • centos怎么执行脚本
  • win7怎么添加此电脑
  • window10预览在哪里找
  • win7系统如何创建管理员账户
  • 解决win10蓝屏
  • windows8鼠标没反应怎么办
  • windows7的使用方法
  • ie9收藏夹
  • linux从一个命令获取数据到另一个命令
  • cocos2d CC_CALLBACK_0/1/2/3之间的区别
  • unity进阶之路
  • 程序员基本入门知识
  • 关于如何用好调查研究推动警务发展
  • vue框架写淘宝购物车
  • angularjs2
  • Linux 中的通配符详解及实例
  • js selectionchange
  • unity c#开发
  • js 小数取整的函数怎么写
  • 不同版本安卓控制台区别
  • js保存设置
  • 残疾人个人所得税怎么申报退税
  • 临时税务登记纳税人
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设