php-预编译
程序员文章站
2024-01-16 08:59:40
...
当出现当量操作sql语句,比如大量将数据插入数据库中,原来的那种单个执行sql语句或者批量执行sql语句的做法,显然是不可行的,因为无论是单个执行还是批量执行都会连续的发送sql语句向数据库中,数据库接到sql语句对它进行编译处理,从而导致效率底下。
而php中出现的预编译解决了这个问题,他的工作原理是:将sql语句发过去,数据库对这一个sql语句进行预编译处理。之后你只需要将要数据发送到数据库即可。
下面通过一个官方的例子来说明这个情况:
prepare("INSERT INTO CountryLanguage VALUES (?, ?, ?, ?)");
$stmt->bind_param('sssd', $code, $language, $official, $percent);$code = 'DEU';$language = 'Bavarian';$official = "F";$percent = 11.2;/* execute prepared statement */$stmt->execute();printf("%d Row inserted.\n", $stmt->affected_rows);/* close statement and connection */$stmt->close();/* Clean up table CountryLanguage */$mysqli->query("DELETE FROM CountryLanguage WHERE Language='Bavarian'");printf("%d Row deleted.\n", $mysqli->affected_rows);/* close connection */$mysqli->close();?>
$stmt->bind_param是进行参数绑定。
$stmt->execute();是进行插入操作。
如果需要插入多个数据,只需要操作$stmt->bind_param和$stmt->execute();即可。
上一篇: URL传参加密 解密后如何获取数据
推荐阅读
-
PHP编译configure时常见错误
-
编译php报错:/usr/bin/ld: cannot find -liconv解决办法
-
infobright 编译安装_MySQL
-
带你玩转Visual Studio——命令行编译C/C++程序
-
hadoop2.2.0集群配置 - 64位系统下编译源码过程
-
hadoop2.2.0集群配置 - 64位系统下编译源码过程
-
phpize编译出错,该怎么处理
-
如何编译PHP源代码介绍ZendEncode的安装方法我今天刚调试成功,不敢独享,拿来献宝_PHP教程
-
lamp-编译安装mysql出现问题,求大神指点
-
composer安装,缺少gd库,编译安装gd报错?