php如何去封装mysqli_prepare?
Jun 06, 2016 pm 08:16 PM
我想把PHP的mysqli_prepare
及其查询过程中需要用到的方法封装到我自己写的类里面去,但是遇到这个问题:
我写的query()
函数接收sql
,charset
,params
参数,其中sql
参数使用占位符以便进行预处理,params
参数是一个数组,是用来绑定占位符的参数的的数组。
那么问题来了,占位符与参数的绑定是利用mysqli_stmt::bind_param()
函数去绑定的,官方的文档说是这样使用的:
<?php $stmt = $mysqli->prepare("INSERT INTO CountryLanguage VALUES (?, ?, ?, ?)"); $stmt->bind_param('sssd', $code, $language, $official, $percent); $code = 'DEU'; $language = 'Bavarian'; $official = "F"; $percent = 11.2; ?>
我不知道我接收的数组的长度(即使用不定参数也不知道),那我要怎样才能绑定参数呢?
如果用if
或者switch
去判断,然后根据相应长度去调用的话,会不会太麻烦,而且不可能包含所有的情况。
所以应该怎样去封装预处理查询的一系列方法呢?
回复内容:
我想把PHP的mysqli_prepare
及其查询过程中需要用到的方法封装到我自己写的类里面去,但是遇到这个问题:
我写的query()
函数接收sql
,charset
,params
参数,其中sql
参数使用占位符以便进行预处理,params
参数是一个数组,是用来绑定占位符的参数的的数组。
那么问题来了,占位符与参数的绑定是利用mysqli_stmt::bind_param()
函数去绑定的,官方的文档说是这样使用的:
<?php $stmt = $mysqli->prepare("INSERT INTO CountryLanguage VALUES (?, ?, ?, ?)"); $stmt->bind_param('sssd', $code, $language, $official, $percent); $code = 'DEU'; $language = 'Bavarian'; $official = "F"; $percent = 11.2; ?>
我不知道我接收的数组的长度(即使用不定参数也不知道),那我要怎样才能绑定参数呢?
如果用if
或者switch
去判断,然后根据相应长度去调用的话,会不会太麻烦,而且不可能包含所有的情况。
所以应该怎样去封装预处理查询的一系列方法呢?

热门文章

热门文章

热门文章标签

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

适用于 Ubuntu 和 Debian 的 PHP 8.4 安装和升级指南

如何设置 Visual Studio Code (VS Code) 进行 PHP 开发
