Commit 38234c61 by Taylor Otwell

Merge pull request #480 from cviebrock/schema-rename

Schema::rename('oldtable','newtable') support
parents c937f98b ef5ab30c
...@@ -41,6 +41,25 @@ class Schema { ...@@ -41,6 +41,25 @@ class Schema {
} }
/** /**
* Rename a database table in the schema.
*
* @param string $table
* @param string $name
* @return void
*/
public static function rename($table, $new_name)
{
$table = new Schema\Table($table);
// To indicate that the table needs to be renamed, we will run the
// "rename" command on the table instance and pass the instance to
// the execute method as calling a Closure isn't needed.
$table->rename($new_name);
return static::execute($table);
}
/**
* Drop a database table from the schema. * Drop a database table from the schema.
* *
* @param string $table * @param string $table
......
...@@ -213,6 +213,18 @@ class MySQL extends Grammar { ...@@ -213,6 +213,18 @@ class MySQL extends Grammar {
} }
/** /**
* Generate the SQL statement for a rename table command.
*
* @param Table $table
* @param Fluent $command
* @return string
*/
public function rename(Table $table, Fluent $command)
{
return 'RENAME TABLE '.$this->wrap($table).' TO '.$this->wrap($command->name);
}
/**
* Generate the SQL statement for a drop table command. * Generate the SQL statement for a drop table command.
* *
* @param Table $table * @param Table $table
......
...@@ -199,6 +199,18 @@ class Postgres extends Grammar { ...@@ -199,6 +199,18 @@ class Postgres extends Grammar {
} }
/** /**
* Generate the SQL statement for a rename table command.
*
* @param Table $table
* @param Fluent $command
* @return string
*/
public function rename(Table $table, Fluent $command)
{
return 'ALTER TABLE '.$this->wrap($table).' RENAME TO '.$this->wrap($command->name);
}
/**
* Generate the SQL statement for a drop table command. * Generate the SQL statement for a drop table command.
* *
* @param Table $table * @param Table $table
...@@ -302,7 +314,7 @@ class Postgres extends Grammar { ...@@ -302,7 +314,7 @@ class Postgres extends Grammar {
*/ */
public function drop_foreign(Table $table, Fluent $command) public function drop_foreign(Table $table, Fluent $command)
{ {
return $this->drop_constraint($table, $command); return $this->drop_constraint($table, $command);
} }
/** /**
......
...@@ -202,6 +202,18 @@ class SQLite extends Grammar { ...@@ -202,6 +202,18 @@ class SQLite extends Grammar {
} }
/** /**
* Generate the SQL statement for a rename table command.
*
* @param Table $table
* @param Fluent $command
* @return string
*/
public function rename(Table $table, Fluent $command)
{
return 'ALTER TABLE '.$this->wrap($table).' RENAME TO '.$this->wrap($command->name);
}
/**
* Generate the SQL statement for a drop table command. * Generate the SQL statement for a drop table command.
* *
* @param Table $table * @param Table $table
......
...@@ -213,6 +213,18 @@ class SQLServer extends Grammar { ...@@ -213,6 +213,18 @@ class SQLServer extends Grammar {
} }
/** /**
* Generate the SQL statement for a rename table command.
*
* @param Table $table
* @param Fluent $command
* @return string
*/
public function rename(Table $table, Fluent $command)
{
return 'ALTER TABLE '.$this->wrap($table).' RENAME TO '.$this->wrap($command->name);
}
/**
* Generate the SQL statement for a drop table command. * Generate the SQL statement for a drop table command.
* *
* @param Table $table * @param Table $table
...@@ -320,7 +332,7 @@ class SQLServer extends Grammar { ...@@ -320,7 +332,7 @@ class SQLServer extends Grammar {
*/ */
public function drop_foreign(Table $table, Fluent $command) public function drop_foreign(Table $table, Fluent $command)
{ {
return $this->drop_constraint($table, $command); return $this->drop_constraint($table, $command);
} }
/** /**
......
...@@ -145,6 +145,17 @@ class Table { ...@@ -145,6 +145,17 @@ class Table {
} }
/** /**
* Rename the database table.
*
* @param string $name
* @return Fluent
*/
public function rename($name)
{
return $this->command(__FUNCTION__, compact('name'));
}
/**
* Drop the database table. * Drop the database table.
* *
* @return Fluent * @return Fluent
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment