位置: 编程技术 - 正文

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

  • 个人所得税手续费返还增值税税率
  • 疫情捐款收据有什么用吗
  • 红冲以前年度收入成本的账务处理
  • 研发支出月末结转转去哪里?
  • 个人所得税年底返税
  • 怎么在网上申请电话卡
  • 调整以前年度递延收益确认收入账务处理
  • 加工费的计提工资账务处理
  • 罚款所得税调整
  • 公司土地使用税
  • 去年成立的公司今年需要年检吗
  • 退回多交企业所得税分录
  • 建筑业异地预缴税款的会计分录
  • 河道维护费所有权归属
  • 每月交的社保什么时候到账
  • 企业如何实现资源共享
  • 进货会计凭证
  • 支付境外佣金的记账凭证
  • 什么是销售利润率和成本利润率
  • 应收账款及票据
  • 小规模纳税人不开票收入填在哪里
  • 已申报未导入什么意思呀
  • 发票认证的三种方式
  • 远期外汇合约套期会计分录
  • 应收票据到期收回时和未到期转让时
  • 分摊本月领用材料的成本差异
  • win101709密钥
  • 施工企业工程结算
  • thinkphp实现163、QQ邮箱收发邮件的方法
  • 非货币性资产投资个人所得税
  • 如何使用nodejs
  • 债务重组亏损计入
  • 小企业法人怎么交社保
  • 企业没有实缴
  • 深入浅出讲解傅里叶变换
  • 工资一定要对公发吗
  • 全局平均池化(GAP)层
  • echarts api文档
  • hostnamectl命令可以永久修改主机名
  • laravel 实例
  • 溢价购买子公司账务处理
  • 命令m文件
  • 加工票可以抵扣吗
  • 增值税申报表销项税额怎么算?
  • 供货单位与开票单位不一致
  • 沙箱支付宝app正式版
  • 其他资本公积主要包括
  • mysql数据库性能监控
  • 交强险还要交车船税?
  • 出售其他债权投资产生的收益为什么计入留存收益
  • 印花税缴款了发票怎么查
  • 营业外收入账务处理方法
  • 待认证进项税额借贷方向
  • 技术服务费收入会计分录怎么写
  • 360天认证期是什么时候发布的
  • 公司缴纳社保如何转为个人缴纳
  • 对公账户明细入账怎么查
  • winXP系统下qq不能视频聊天该怎么办?
  • win8.1开机进入桌面
  • 注意 Win/WP8.1开发者账户现已迁移到全新Win10开发者中心仪表盘
  • win1020h2版本要更新多久
  • win10周年版
  • surface pro7应用
  • Win10红石版Edge浏览器新扩展功能:关灯(附扩展程序使用)
  • jquery禁止点击事件
  • jquery.ui
  • dos命令/s
  • eclipse awt
  • 用python播放音乐
  • javascript中的getElementById
  • 安卓框架是什么怎么用
  • python多线程异常后所有线程均不往下执行
  • python基本介绍
  • 江苏国税申报
  • 河北省发票查询真伪查询国税
  • 查询发票号码
  • 广东省电子税务局app下载官网
  • 长春市朝阳区公安局电话
  • 怎么查询地税信息表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设