位置: 编程技术 - 正文

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
  • 营业外支出怎么冲减
  • 两家企业共用一个厂区
  • 什么叫盘活存量股票
  • 代理报关费0税率
  • win7的本地连接在哪
  • 日记账登记错了怎么办
  • 时序模型算法
  • axios异步请求数据
  • 短期投资取得的收益
  • 发票已认证当月未申报怎么办
  • 运费抵扣怎么算
  • 翡翠湾攻略
  • 资金筹集业务核算实训内容
  • php连接mysql数据库四步
  • vue思维导图怎么下载
  • auto系列软件
  • Vue(ref和$refs属性介绍与使用)
  • 防抖节流实现原理
  • php图像识别
  • hexdump windows
  • 自建自用 房产税
  • 外贸企业代理出口退税给谁
  • 固定资产报废清理怎么做账务处理的
  • 图书为什么不能退货
  • python__get__
  • 银行手续费和利息会计分录
  • 收到汇算清缴的退税需要交税吗
  • 代收往来款的会计分录
  • 汽车维修行业工时标准
  • 已抵扣的发票冲红会计分录
  • 科技型中小企业享受优惠税收政策
  • sql2017附加数据库
  • 其他权益工具的公允价值变动计入哪里
  • 合伙企业怎么注册公司持股人
  • 超市出租摊位交什么税
  • 外出经营必须办理外管证吗
  • 被法院扣的钱怎么又退回来了
  • 银企对账操作流程
  • 净资产=资产-负债
  • sqlserver 教程
  • 电脑windows怎么查
  • xp怎么解压文件
  • linux虚拟机基本操作
  • fedora29
  • win8系统开机桌面文件不见了
  • exfat装win7
  • 修改centos的ip
  • win7如何限制网速
  • 打开电脑显示配置windows,可是一直0%,怎么办
  • android开发流程
  • JavaScript中的变量名不区分大小写
  • 我决定放弃了你却对我笑了
  • python编程中的函数
  • python怎么写链表
  • mac如何配置pycharm
  • django pypy
  • go语言websocket
  • android 全局viewmodel
  • 广东增值税电子普通发票怎么开
  • 公司开票明细如何查询
  • 税务局航天信息的操作流程
  • 减免税的三种方式
  • 江西公积金提取代办
  • 华数tv业务认证账号
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设