0

我正在尝试使用以下代码向表中添加一列。

ALTER IGNORE TABLE `EWRcarta_history`
    ADD `history_ip` int(10) unsigned NOT NULL DEFAULT '0'

我使用 IGNORE 是因为出于各种我不想进入的原因,这段代码可能会被多次调用。我想添加该列,但如果该列已存在,请忽略该错误。我没有默默地失败并继续前进,而是收到以下错误:

#1060 - Duplicate column name 'history_ip'

我能做些什么来完成这项工作吗?

4

1 回答 1

0

我最终使用了一个函数来处理这个问题:

 public static function addColumnIfNotExist($db, $table, $field, $attr)
 {
  if ($db->fetchRow('SHOW columns FROM `'.$table.'` WHERE Field = ?', $field))
  {
   return false;
  }

  return $db->query("ALTER TABLE `".$table."` ADD `".$field."` ".$attr);
 }

然后当然我使用如下功能:

self::addColumnIfNotExist($db, "table", "column", "attributes");
于 2010-11-29T08:16:42.940 回答