我对Yii很陌生,我已经用 Yii 工作了3个星期, Yii 对我帮助很大。我的应用程序工作正常,直到我的同事需要在数据库中进行一些更改。他们删除了一个名为STORE_PROCESSOR
的表,并创建了两个名为BIG_STORE_PROCESSOR
和SMALL_STORE_PROCESSOR
的新表。他们还在表格中添加了一个新列。
问题是当我尝试使用Gii为这些新表创建模型时,Gii告诉这些表不存在于数据库中。 Gii知道的是STORE_PROCESSOR
表仍然存在于数据库中。 CActiveRecord
也不知道已添加到表格中的新列。
我们正在使用Oracle 10g XE数据库和Yii 1.1.14
这是我的config/main.php
<?php
// uncomment the following to define a path alias
// Yii::setPathOfAlias('local','path/to/local-folder');
// This is the main Web application configuration. Any writable
// CWebApplication properties can be configured here.
return array(
'basePath'=>dirname(__FILE__).DIRECTORY_SEPARATOR.'..',
'name'=>'Portal Online Store',
'language'=>'en',
'theme'=>'default',
// preloading 'log' component
'preload'=>array('log'),
// autoloading model and component classes
'import'=>array(
'application.models.*',
'application.components.*',
),
'modules'=>array(
// uncomment the following to enable the Gii tool
'gii'=>array(
'class'=>'system.gii.GiiModule',
'password'=>'bolu',
// If removed, Gii defaults to localhost only. Edit carefully to taste.
'ipFilters'=>array('127.0.0.1','::1'),
),
),
// application components
'components'=>array(
'user'=>array(
// enable cookie-based authentication
'allowAutoLogin'=>true,
),
// uncomment the following to enable URLs in path-format
'urlManager'=>array(
'urlFormat'=>'path',
'rules'=>array(
'<controller:\w+>/<id:\d+>'=>'<controller>/view',
'<controller:\w+>/<action:\w+>/<id:\d+>'=>'<controller>/<action>',
'<controller:\w+>/<action:\w+>'=>'<controller>/<action>',
),
),
// uncomment the following to use a MySQL database
'db'=>array(
'connectionString'=>'oci:dbname=152.116.31.148:1521/XE;charset=UTF8',
//'emulatePrepare' => true,
'username' => 'xxxxxxxxx',
'password' => '******',
//'charset' => 'utf8',
),
'errorHandler'=>array(
// use 'site/error' action to display errors
'errorAction'=>'site/error',
),
'log'=>array(
'class'=>'CLogRouter',
'routes'=>array(
array(
'class'=>'CFileLogRoute',
'levels'=>'error, warning',
),
// uncomment the following to show log messages on web pages
/*
array(
'class'=>'CWebLogRoute',
),
*/
),
),
),
// application-level parameters that can be accessed
// using Yii::app()->params['paramName']
'params'=>array(
// this is used in contact page
'adminEmail'=>'webmaster@example.com',
'timeout'=>'900',
'timezone'=>'Asia/Jakarta'
),
);
答案 0 :(得分:1)
您需要刷新数据库模式,运行以下代码以便删除它(使用包含以下代码的操作创建控制器...)
public action refreshSchema() { // Load all tables of the application in the schema Yii::app()->db->schema->getTables(); // clear the cache of all loaded tables Yii::app()->db->schema->refresh(); }
另一种简单的方法是转到运行时/缓存目录并清除所有* .bin文件,这样它就会强制创建新的缓存模式。
最后一种方法是刷新特定表的缓存
Yii::app()->db->schema->getTable('tablename', true);
答案 1 :(得分:0)
问题不在Yii中。我们是Yii的新手,也是Oracle数据库的新手。更改表格后,您必须更新WWW_TAB_COLUMNS
中名为WWW_TAB_CONS
,WWW_TABLES
,SQL developer (Oracle DB)
的表格。如果不知道,Yii
不知道数据库中的任何更改。 WWW_TAB_COLUMNS
包含有关数据库中存在的所有列的信息。然后,WWW_TAB_CONS
包含有关数据库中存在的所有约束的信息。最后,WWW_TABLES
包含有关数据库中存在的所有表的信息。在进行CRUD操作之前,Web应用程序看起来必须首先看到这些表