php如何去封装mysqli_prepare?

WBOY
Freigeben: 2016-06-06 20:16:24
Original
1496 人浏览过

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

prepare("INSERT INTO CountryLanguage VALUES (?, ?, ?, ?)");
$stmt->bind_param('sssd', $code, $language, $official, $percent);
$code = 'DEU';
$language = 'Bavarian';
$official = "F";
$percent = 11.2;
?> 
Nach dem Login kopieren
Nach dem Login kopieren

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

回复内容:

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

prepare("INSERT INTO CountryLanguage VALUES (?, ?, ?, ?)");
$stmt->bind_param('sssd', $code, $language, $official, $percent);
$code = 'DEU';
$language = 'Bavarian';
$official = "F";
$percent = 11.2;
?> 
Nach dem Login kopieren
Nach dem Login kopieren

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

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!