有没有办法可以在 laravel 4 中使用 eloquent 或 fluent 截断数据库中的所有表?我不想指定表名,我只想截断所有表。换句话说,清空所有表。
问问题
41013 次
7 回答
58
注意:
doctrine/dbal
执行此操作需要包
所以请确保已安装 composer require doctrine/dbal
1.获取所有表名
$tableNames = Schema::getConnection()->getDoctrineSchemaManager()->listTableNames();
2.遍历表名数组并用Schema Builder截断
foreach ($tableNames as $name) {
//if you don't want to truncate migrations
if ($name == 'migrations') {
continue;
}
DB::table($name)->truncate();
}
帮助:如果您遇到了一些错误,例如
SQLSTATE [42000]:语法错误或访问冲突:1701 无法截断外键约束中引用的表
您可以禁用外键检查
Schema::disableForeignKeyConstraints();
并确保重新启用它
Schema::enableForeignKeyConstraints();
于 2013-09-20T06:19:52.033 回答
12
这是我基于@Hao Luo的回答。此外,它还有以下优点:
- 你不需要安装任何额外的包(不需要学说)
- 它非常支持 Laravel 5(或更新版本)
- 它禁用外键约束(如果你在不关心订单的情况下截断并启用外键约束,你可能会得到一个错误)
这是代码:
DB::statement("SET foreign_key_checks=0");
$databaseName = DB::getDatabaseName();
$tables = DB::select("SELECT * FROM information_schema.tables WHERE table_schema = '$databaseName'");
foreach ($tables as $table) {
$name = $table->TABLE_NAME;
//if you don't want to truncate migrations
if ($name == 'migrations') {
continue;
}
DB::table($name)->truncate();
}
DB::statement("SET foreign_key_checks=1");
希望你喜欢!:)
于 2018-06-18T07:31:39.737 回答
3
在 laravel 5 中, migrate:fresh 将删除数据库中的所有表(即使表与 migrate 无关)
于 2019-03-06T13:06:23.293 回答
2
用这个:
$tables = DB::select('SHOW TABLES');
// it do truncate all tables in database
foreach($tables as $table){
if ($table == 'migrations') {
continue;
}
DB::table($table->Tables_in_portal_test)->truncate();
}
记住你导入
使用 Illuminate\Support\Facades\DB;
PD:Tables_in_YOUR_DATABASE_NAME
于 2019-11-16T16:20:02.420 回答
0
这就是我截断数据库中所有表(包括表异常)的方式,它对我有用。
// set tables don't want to trucate here
$excepts = ['migrations'];
$tables = DB::connection()
->getPdo()
->query("SHOW FULL TABLES")
->fetchAll();
$tableNames = [];
$keys = array_keys($tables[0]);
$keyName = $keys[0];
$keyType = $keys[1];
foreach ($tableNames as $name) {
//if you don't want to truncate migrations
if (in_array($name[$keyName], $excepts))
continue;
// truncate tables only
if('BASE TABLE' !== $name[$keyType])
continue;
\DB::table($name)->truncate();
}
于 2014-07-21T01:10:48.190 回答
0
根据之前的答案,我将表名直接过滤到 SQL 查询中。我同意这是一个小的优化,但可以避免不必要的循环。
protected function truncateDatabase($excepts = []): void
{
$excepts = array_merge(['migrations'], $excepts);
\DB::statement('SET foreign_key_checks=0');
$table_names = \DB::query()->select('TABLE_NAME')->from('information_schema.tables')
->where('TABLE_SCHEMA', \DB::getDatabaseName())
->whereNotIn('TABLE_NAME', $excepts)
->get()
->pluck('TABLE_NAME')
->toArray();
foreach ($table_names as $table_name) {
\DB::table($table_name)->truncate();
}
\DB::statement('SET foreign_key_checks=1');
}
于 2019-10-30T09:33:23.973 回答
0
您可以将其添加到您的基本测试用例类中
protected static function truncateTableAll(array $skip = [])
{
Schema::disableForeignKeyConstraints();
foreach (Schema::getConnection()
->getDoctrineSchemaManager()
->listTableNames() as $name) {
if ($name == 'migrations' || in_array($name, $skip)) {
continue;
}
DB::table($name)->truncate();
}
Schema::enableForeignKeyConstraints();
}
于 2021-03-08T05:30:14.970 回答