我正在使用一个 php 类生成器。基本上它在mysql中获取指定的表并相应地生成类。你会明白的:
....
$sql_r = mysqli_query($sql_conn, "select * from $sql_table;");
$sql_Fs = $sql_r->fetch_fields();
?>
<pre class="php">
<?php
class <?php echo $sql_table; ?>{
<?php foreach($sql_Fs as $sql_f) echo "var ".$sql_f->name."; "; ?>
function sql_insert(){
$sql_conn = sql_conn();
$sql_stmt =$sql_conn->prepare("INSERT INTO <?php echo $sql_table; ?> (<?php foreach($sql_Fs as $K=>$sql_f){ if($K>1){ echo ", ";} if($K>0){ echo $sql_f->name; }} ?>) VALUES (<?php foreach($sql_Fs as $K=>$sql_f){ if($K>1){ echo ", "; } if($K>0) {echo "?"; }} ?>)");
$sql_stmt->bind_param('', <?php foreach($sql_Fs as $K=>$sql_f){ if($K>1){ echo ", "; } if($K>0){ echo "\$this->".$sql_f->name; }} ?>);
//^^^^ Need data type
if(!$sql_stmt->execute()){ error_log($sql_stmt->error); $R = false; }else{ $R = true; }
$sql_stmt->close(); $sql_conn->close(); return $R;
}
.....
我卡住的地方是设置 bind_param 数据类型。我发现你可以得到fetch_field->type
它,它会给你一个类型的数值(参见http://php.net/manual/en/mysqli-result.fetch-field.php)。
有没有办法直接获取数据类型对应的字母?(s,i,d,b) 还是我真的需要创建一个函数来从数字 (fetch_field->type) 转换为相应的字母?
仅供参考:目前它输出如下内容:
function sql_insert(){
$sql_conn = sql_conn();
$sql_stmt =$sql_conn->prepare("INSERT INTO user (flag, name, mail, pass) VALUES (?, ?, ?, ?)");
$sql_stmt->bind_param('', $this->flag, $this->name, $this->mail, $this->pass);
if(!$sql_stmt->execute()){ error_log($sql_stmt->error); $R = false; }else{ $R = true; }
$sql_stmt->close(); $sql_conn->close(); return $R;
}
我知道它不完整,但这是另一个问题;)干杯