これとまったく同じシナリオがあり、それを解決するために独自の関数を作成することになりました。この関数は YAML ファイルを調べ、各テーブル名を読み取りclassName:
、テーブル プレフィックスなしで適切なエントリを追加します。
関数は次のとおりです。
const TABLE_PFX = 'tableName:';
const CLASS_PFX = 'className:';
function AddClassNames($yamlPath) {
$tempFilePath = $yamlPath . '.old';
rename($yamlPath, $tempFilePath);
$tempFile = fopen($tempFilePath, 'r');
$yamlFile = fopen($yamlPath, 'w');
while (!feof($tempFile)) {
$line = fgets($tempFile);
fwrite($yamlFile, $line);
if ($index = strpos($line, TABLE_PFX)) {
$tableName = trim(substr($line, $index + strlen(TABLE_PFX) + 1));
$className = substr($tableName, 4);
$className = strtocamel($className);
$classLine = str_replace(TABLE_PFX, CLASS_PFX, $line);
$classLine = str_replace($tableName, $className, $classLine);
fwrite($yamlFile, $classLine);
}
}
fclose($tempFile);
fclose($yamlFile);
unlink($tempFilePath);
}
そして、これが私がそれを使用する方法です:
Doctrine_Core::generateYamlFromDb($yamlPath);
AddClassNames($yamlPath);
Doctrine_Core::generateModelsFromYaml($yamlPath, 'models',
array('doctrine'),
array('generateTableClasses' => true,));
もう 1 つ注意してください。この方法では、Doctrinedatabase_table_name
を PHP 対応の に変換するClassName
余裕がないため、自分で行う必要があります。ここstrtocamel
から機能を使用しました。