mysql使用mix列静态和动态创建表

时间:2018-01-23 18:45:57

标签: php mysql database wordpress

我在使用foreach结果中的动态列创建表时遇到问题。

准备专栏的代码:

$fields = $wpdb->get_results("SELECT goal_id FROM wpgetyp_goalsettings WHERE goaltype IN('daily','weekly') AND user_id='$current_user->ID'");
foreach ($fields as $field) {
    $cfield = "field_$field->goal_id int(5) NOT NULL,";
}

结果:

field_1 int(5) NOT NULL,field_2 int(5) NOT NULL,field_3 int(5) NOT NULL,field_4 int(5) NOT NULL,field_5 int(5) NOT NULL,

创建表格的代码:

$table_name = $wpdb->prefix.'user_'.$current_user->ID;
if($wpdb->get_var("SHOW TABLES LIKE '$table_name'") != $table_name) {
     //table not in database. Create new table
     $charset_collate = $wpdb->get_charset_collate();

     $sql = "CREATE TABLE $table_name (
          id int(10) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
          user_id varchar(15) NOT NULL,
          goals_type varchar(10) NOT NULL,
          goals_date date NOT NULL,
          start_time time NOT NULL,
          end_time time NOT NULL,
          $cfield
          lead_type varchar(50) NOT NULL,
          entry_date timestamp
     ) $charset_collate;";
     require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
     dbDelta( $sql );
}
else{
}

注意$cfield。它只会在创建表时写入最后的结果。在表创建过程中只会包含field_5

2 个答案:

答案 0 :(得分:2)

您使用新值覆盖每个结果。相反,你需要连接所有这些值:

$fields = $wpdb->get_results("SELECT goal_id FROM wpgetyp_goalsettings WHERE goaltype IN('daily','weekly') AND user_id='$current_user->ID'");
$cfield = "";

foreach ($fields as $field) {
    // Long way of string concatenation
    $cfield = $cfield . "field_$field->goal_id int(5) NOT NULL, ";
    // Short way, mentioned by @FrankerZ in the comments (chose one)
    // $cfield .= "field_$field->goal_id int(5) NOT NULL, ";
}

答案 1 :(得分:0)

您只需使用array_map()implode()即可完成此操作:

,

上面的块也会在最后处理悬空playersg[draw]。有关示例,请参阅this output