mysql——预处理Prepared某需求某一条 SQL 语句可能会被反复调用执行,或者每次执行的时候只有个别的值不同(比如 select 的 where 子句值不同 , update 的 set 子句值不同 , insert 的 values 值不同) 。如果每次都需要经过上面的词法语义解析、语句优化、制定执行计划等,则效率就明显不行了 。
所谓预编译语句就是将此类 SQL 语句中的值用占位符替代,可以视为将 SQL 语句模板化或者说参数化,一般称这类语句叫Prepared Statements 。
预编译语句的优势在于归纳为:一次编译、多次运行,省去了解析优化等过程;此外预编译语句能防止 SQL 注入 。
注意:虽然可能是通过预处理 SQL 的方式一定程度的提高了效率,但是对于优化而言 , 最优的执行计划不是光靠 SQL 语句的模板化来实现的,往往还是需要通过具体值来预估出成本代价 。
MySQL 官方将 prepare、execute、deallocate 统称为 PREPARE STATEMENT 。
步骤大概分为四步:
1 set —— SET @s = 'SELECT SQRT(POW(?,2)POW(?,2)) AS hypotenuse';
2 prepare —— PREPARE stmt2 FROM @s;
3 execute —— EXECUTE stmt2;
4 deallocate —— DEALLOCATE PREPARE stmt2;
Mysql存储过程是在创建时预编译还是在执行时预编译,怎么能看出来或者怎么测出来语法
show create {procedure|function} sp_name;
例如查看存储过程myPro的创建语句
show create procedure myPro;
查看自定义函数myFunc的创建语句
show create function myFunc;
mysql 5.5.54 不支持 预编译吗mysql 5.5.54 支持 预编译
开始安装mysql
1.1 创建用户和组
groupadd mysql
useradd mysql -s /sbin/nologin -M -g mysql
1.2 解压编译MySQL
cd /root/tools
tar zxf mysql-5.5.32.tar.gz
cd mysql-5.5.32
#图一
cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.5.32 \
-DMYSQL_DATADIR=/application/mysql-5.5.32/data \
-DMYSQL_UNIX_ADDR=/application/mysql-5.5.32/tmp/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii \
-DENABLED_LOCAL_INFILE=ON \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
-DWITHOUT_PARTITION_STORAGE_ENGINE=1 \
-DWITH_FAST_MUTEXES=1 \
-DWITH_ZLIB=bundled \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_READLINE=1 \
-DWITH_EMBEDDED_SERVER=1 \
-DWITH_DEBUG=0
#图二
makemake install
#图三
3
1.3添加链接
ln -s /application/mysql-5.5.32/ /application/mysql
【mysql是怎么预编译的 mysql怎么编程】关于mysql是怎么预编译的和mysql怎么编程的介绍到此就结束了 , 不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。
推荐阅读
- linux怎么开命令行,linux怎样打开命令行
- gis打开时脚本错误,arcgis102脚本错误
- ios如何下载历史版本的软件,ios如何卸载软件
- ios单机破解游戏,ios单机破解版游戏
- 包含稳定的windows系统的词条
- 如何运用大数据做营销,大数据时代如何让营销更精准
- chatgpt中文切换,chatter中文
- 在gis中如何使用分割工具,arcgis如何分割图形
- go语言2018排行 go语言优劣