位置: 编程技术 - 正文

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

  • 公司股权变更要查账吗
  • 已缴纳车船税的车船在同一年度
  • 纳税信用等级评定在哪里查询
  • 残疾人就业保障金会计分录怎么做
  • 交易性金融资产和其他权益工具投资的区别
  • 三供一业移交内容
  • 国税地税合并后叫什么名称
  • 企业注销资产负债表年初数要调整吗?
  • 一般纳税人企业所得税多久申报一次
  • 集团公司内部调动
  • 担保费能抵扣吗
  • 业务招待费支出扣除标准
  • 增值税免税和即税的区别
  • 核销贷款收回会计分录
  • 更新改造过程中被替换部件的账面价值
  • 境外企业提供国外服务
  • 进项和销项单价的比例
  • 建筑安装预缴增值税
  • 每股收益怎么计算净利润
  • 企业转让销售配额怎么算
  • 拆迁安置房如何更名
  • 企业收到政府扶贫资金补助及运用补助金怎么做账
  • 推广费属于什么科目
  • 网件R6400路由器怎么样?网件R6400上网与传输评测的教程
  • 公司一般账户不用了会怎么样
  • 买入投资性房地产的会计处理
  • 无法添加用户和组
  • php中的header函数
  • 销售返点的账务怎么处理
  • phpstudy的ftp
  • 社保缴费半年
  • 增值税税率类型
  • 应付票据核算的票据包括
  • 企业向个人借款是否合法
  • php常用设计模式(大总结)
  • php reference
  • 企业和单位往来怎么做账
  • 接受股权投资账务处理
  • 前端常见面试
  • 员工安全培训费可以计入安全费用吗
  • 事业结余是事业单位当年全部收支相抵后的余额
  • 或有资产确认的前提为什么是
  • 网上学电脑哪个软件好
  • 营运资金为正数说明企业什么
  • 公司销售不动产增值税
  • 短期贷款利息支付
  • 银行手续费已扣发票未开的账务处理
  • mysql show privileges
  • 其他业务成本借方表示什么
  • 电子承兑汇票转给下家
  • 银行代发的工资公司要求返还然后发一半
  • 车辆购置税计入什么科目
  • 小型微利企业预缴企业所得税怎么算
  • 与其他企业联营
  • 补交上年度的企业所得税税款计入什么科目
  • mysql -u -p -s
  • jmeter怎么连接数据库
  • centos crond
  • 如何进入opencore引导
  • mac邮件应用规则
  • ubuntu搭建go环境
  • MSAPI.DAT,WINDNSAPI.DAT是什么文件
  • linux文件latin1转换为utf
  • linux查看指定内容
  • win7系统怎么设置开机启动项
  • 电子版win10怎么安装
  • win10系统关闭安全中心
  • quick cocos UIListView之isItemInViewRect方法修正
  • cocos2d-js-min.js
  • javascript definitive guide
  • js中事件的三要素
  • jquery选择指定标签
  • 异步promise原理
  • 动态效果怎么设置
  • 装饰装修公司需要什么
  • 吉林省电子税务局操作手册
  • 电子税务局怎么添加银行账户信息
  • 江苏预包装食品备案网上流程
  • 公司变更税务局
  • 江苏税务个税查询
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设