位置: 编程技术 - 正文

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变量(几个比较重要的家风)

  • 税务师入会与不入会冲突
  • 个人接私活需要开票,可以让别的公司帮忙开票吗?
  • 个人免征税额
  • 个税扣除项生效日期
  • 装水表财务是什么费用
  • 费用票据包括哪些
  • 长期租赁存在的主要原因为什么是节税
  • 个体工商户的税收优惠政策有哪些
  • 固定资产机器设备使用年限
  • 购买方红字信息表开具流程图
  • 销售返点的账务处理及税务处理
  • 记账凭证保存年限2019
  • 已抵扣未认证的发票
  • 应付工资和实付工资的差额叫什么
  • 设备维修费增值税
  • 经营租赁是什么意思
  • 银行贷款需要走第三方账户,第三方需要提供身份证
  • deepin如何设置网络
  • 资产处置收益与固定资产清理
  • PHP:mb_ereg_search_getregs()的用法_mbstring函数
  • linux中cw
  • 拼多多改地址怎么改视频
  • 新会计准则5步法
  • 哥本哈根的地形
  • thinkphp assign函数
  • thinkphp excel
  • thinkphp框架入门
  • 利用php判断文件是否存在
  • 结转完工产品成本的会计分录
  • 社保基数是按基本工资还是应发工资
  • 预交的企业所得税如何记账
  • 出纳各种费用如何归类
  • javascript和java有什么区别
  • 生产车间领用材料的会计分录
  • pythonif嵌套语句
  • System.Data.SQLite 数据库详细介绍
  • sql优化常用的15种方法
  • 本年缴纳上年的所得税填年报
  • 电梯维保费属于什么费用
  • 企业每月应交哪几种税费
  • 属于流动资产的项目有
  • 客户多付的尾数计入什么科目
  • 顺流交易为什么也要减
  • 在建工程里面的费用最后怎样结转
  • 企业应如何合理安排筹资期限的组合方式,优化资金结构
  • 初始数据都录入什么意思
  • 收到去年所得税退税款会计分录
  • 库存股的处理方式
  • 存货报废会计账务处理
  • 工程款打入个人账户扣税吗
  • oracle序列修改初始值
  • mysql5.6怎么用
  • xp系统的输入法在哪里设置
  • vista技巧:更改电源默认按钮为关机
  • 使用组策略可控制什么
  • mac音频设置在哪里
  • WIN764位系统8G内存识别一半解决办法
  • centos7 swap大小设多少
  • xp升win10教程
  • win8如何升级到win10系统版本
  • 下载手游网
  • javascript标题
  • 微信怎么导入主题模块
  • perl的$_
  • Node.js中的全局对象有
  • android抓取各种log的方法
  • android app 开发框架
  • linux timeline
  • python xml.etree.ElementTree遍历xml所有节点实例详解
  • python append 浅拷贝
  • python mem
  • javascript面向对象编程指南第三版
  • python 遍历数组
  • 完税证明和发票的关系
  • 江苏国税申报怎么操作流程
  • 季度申报表如何填写
  • 你认为作为一名护士应具备哪些素质
  • 尾矿治理文件
  • 小规模纳税人的增值税怎么计算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设