我是Yii的新手,我尝试使用“yiic migrate”命令设置数据库。
我的迁移看起来像这样:
<?php
class m140131_054313_crear_base_de_datos extends CDbMigration
{
public function up()
{
$this->createTable('tbl_proveedor', array(
'id' => 'pk',
'nombre' => 'string NOT NULL',
'telefono' => 'text NULL',
'direccion' => 'text DEFAULT NULL',
'pagina' => 'text DEFAULT NULL',
'fecha_ingreso' => 'datetime DEFAULT NULL',
'usuario_creacion' => 'int(11) DEFAULT NULL',
), 'ENGINE=InnoDB');
}
...
但是我在提示中遇到了这个错误:
Yii Migration Tool v1.0 (based on Yii v1.1.14)
Total 1 new migration to be applied:
m140131_054313_crear_base_de_datos
Apply the above migration? (yes|no) [no]:y
*** applying m140131_054313_crear_base_de_datos
> create table tbl_proveedor ...exception 'CDbException' with message 'CDbCo
mmand failed to execute the SQL statement: CDbCommand failed to prepare the SQL
statement: SQLSTATE[HY000]: General error: 1 near "ENGINE": syntax error. The SQ
L statement executed was: CREATE TABLE 'tbl_proveedor' (
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
"nombre" varchar(255) NOT NULL,
"telefono" text NULL,
"direccion" text DEFAULT NULL,
"pagina" text DEFAULT NULL,
"fecha_ingreso" datetime DEFAULT NULL,
"usuario_creacion" int(11) DEFAULT NULL
) ENGINE=InnoDB' in C:\xampp\htdocs\yii\framework\db\CDbCommand.php:358
...
你有什么建议吗?
非常感谢。
答案 0 :(得分:0)
此迁移应用于SQLite
数据库,引擎不是语言构造。
您可能遇到的错误是控制台应用程序的配置不同,它引用了生成的SQLite数据库。
确保您在控制台中拥有以下内容:
'db'=>array(
'connectionString' => 'mysql:host=localhost;dbname=databasename',
'emulatePrepare' => true,
'username' => 'root',
'password' => 'ur password',
'charset' => 'utf8',
),