Heim  >  Artikel  >  Backend-Entwicklung  >  php如何去封装mysqli_prepare?

php如何去封装mysqli_prepare?

WBOY
WBOYOriginal
2016-06-06 20:16:241559Durchsuche

我想把PHP的mysqli_prepare及其查询过程中需要用到的方法封装到我自己写的类里面去,但是遇到这个问题:
我写的query()函数接收sql,charset,params参数,其中sql参数使用占位符以便进行预处理,params参数是一个数组,是用来绑定占位符的参数的的数组。
那么问题来了,占位符与参数的绑定是利用mysqli_stmt::bind_param()函数去绑定的,官方的文档说是这样使用的:

<code class="php"><?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;
?> </code>

我不知道我接收的数组的长度(即使用不定参数也不知道),那我要怎样才能绑定参数呢?
如果用if或者switch去判断,然后根据相应长度去调用的话,会不会太麻烦,而且不可能包含所有的情况。
所以应该怎样去封装预处理查询的一系列方法呢?

回复内容:

我想把PHP的mysqli_prepare及其查询过程中需要用到的方法封装到我自己写的类里面去,但是遇到这个问题:
我写的query()函数接收sql,charset,params参数,其中sql参数使用占位符以便进行预处理,params参数是一个数组,是用来绑定占位符的参数的的数组。
那么问题来了,占位符与参数的绑定是利用mysqli_stmt::bind_param()函数去绑定的,官方的文档说是这样使用的:

<code class="php"><?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;
?> </code>

我不知道我接收的数组的长度(即使用不定参数也不知道),那我要怎样才能绑定参数呢?
如果用if或者switch去判断,然后根据相应长度去调用的话,会不会太麻烦,而且不可能包含所有的情况。
所以应该怎样去封装预处理查询的一系列方法呢?

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn