位置: 编程技术 - 正文

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

  • 增值税专用发票可以开电子发票吗
  • 农业企业免哪些税款
  • 企业所得税上个月没有计提本月怎么计提
  • 兼职工资如何发放给个人
  • 发票第二年是否可以作废
  • 污水处理费免征增值税申报怎么填写
  • 工业企业销售成本如何计算
  • 如何让自己公司成为供应商
  • 工作未满12个月被辞退时前月平均工资怎么计算
  • 物流企业会计核算的主要内容
  • 跨年收到暂估费用的发票如何处理
  • 代销产品缴纳增值税吗
  • 建筑工程地址
  • 分支机构的固定资产转移如何处理?
  • 销售佣金的税率怎么算
  • 会计人必读的20本书
  • 怎么修改财务负责人信息
  • 一般纳税人税控盘维护费会计分录
  • 卖废品收入没开票怎么办
  • 期初存货余额在哪张表里
  • 购买超市购物卡打几折
  • 股东退股会计科目
  • 房地产企业资金监管账户
  • 苹果手机键盘剪切板在哪里打开
  • 苹果电脑mac系统怎么升级
  • vnisedit 打包
  • 会计分录中结转成本
  • 购销合同违约罚款属什么科目
  • mac怎么切换输入方式
  • 夜间潜水时发现水体
  • last命令详解
  • 端午节发现金怎么说
  • 收到借款时 会计科目怎么做
  • 增值税附加税减免政策2022年
  • 预收款预缴增值税如何核算的
  • 技术研发费用包括哪些
  • sql server数据库异地备份
  • 对公允价值套期的认识
  • 净利润率的计算方法公式
  • 其他应付款做账
  • 加油充值卡有优惠吗
  • 开具的发票是否为印花税的应税凭证?
  • 买车给了上牌费去车管所还用给钱吗
  • 日常费用报销表格
  • a公司刚刚执行了一个采购项目
  • 营业收入增长率分析
  • 员工社保,个税怎么计算
  • 年初资产总额怎么算
  • mysql数据库分区查询
  • 简单谈谈设计与市场的关系
  • ubuntu 连不上网如何排查原因
  • win8局域网共享设置
  • centos真机安装后只有lo
  • win7笔记本电脑怎么重装系统教程
  • win10 mobile下载
  • driver's
  • ubuntu开发板
  • win7系统开机进不去
  • 无法打开opencv2
  • linux文件压缩和备份实验
  • win7 64位旗舰版电脑被唤醒之后显示器依然黑屏怎么办?
  • cocos2dx 3.17
  • 人物移动素材
  • 怎样判断滚动和滑动
  • node搭建博客
  • bat批处理执行cmd命令
  • python pyb库
  • js怎么检查错误
  • 配置ip地址的方法有哪几种
  • shell 生成随机数每次运行都不一样
  • PYTHON内置函数,标准库,三方库的区别
  • jquery访问本地html
  • 晋税通注册
  • 税务机关一案双查管理办法
  • 江西烟草公司局长
  • 税务局 笔录
  • 长沙房产税如何征收
  • 土地招拍挂土地出让金
  • 2017企业所得税年度申报表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设