generated from liutk/owl-admin-base
113 lines
4.5 KiB
PHP
113 lines
4.5 KiB
PHP
<?php
|
|
|
|
namespace Database\Seeders;
|
|
|
|
use Illuminate\Database\Seeder;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Support\Str;
|
|
use Throwable;
|
|
use App\Models\Keyword;
|
|
|
|
class KeywordDictSeeder extends Seeder
|
|
{
|
|
/**
|
|
* Run the database seeds.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function run()
|
|
{
|
|
DB::connection('djc_mysql')->getPdo()->exec("SET NAMES 'utf8'");
|
|
$oldDicts = DB::connection('djc_mysql')->table('t_data_dict')->get();
|
|
|
|
$newKeywords = [];
|
|
|
|
$parentList = Keyword::whereIn('key', ['financial_cate', 'file_cate', 'department', 'area_cate', 'organized_body', 'housing_estate', 'domicile', 'nation', 'political_face','educational_level','oral_disputes','sanitary_inspection', 'book_cate', 'business_area','money_cate', 'welfare_cate', 'job_cate'])->get();
|
|
|
|
$buildings = [];
|
|
foreach($oldDicts as $dict){
|
|
if(empty($dict->dictKey) || empty($dict->valid)){
|
|
continue;
|
|
}
|
|
$_parent = $_keyword = null;
|
|
switch($dict->dictKey){
|
|
case 'financeReportType'://财务报表类型
|
|
$_parent = $parentList->where('key', 'financial_cate')->first();
|
|
break;
|
|
case 'profileType'://档案类型
|
|
$_parent = $parentList->where('key', 'file_cate')->first();
|
|
break;
|
|
case 'addrType'://企业地区管理
|
|
$_parent = $parentList->where('key', 'business_area')->first();
|
|
break;
|
|
case 'bookType'://图书类型
|
|
$_parent = $parentList->where('key', 'book_cate')->first();
|
|
break;
|
|
case 'court'://小区管理
|
|
$_parent = $parentList->where('key', 'housing_estate')->first();
|
|
break;
|
|
case 'workType'://工种管理
|
|
$_parent = $parentList->where('key', 'job_cate')->first();
|
|
break;
|
|
case 'welfType'://福利类型
|
|
$_parent = $parentList->where('key', 'welfare_cate')->first();
|
|
break;
|
|
case 'society'://社别
|
|
$_parent = $parentList->where('key', 'organized_body')->first();
|
|
break;
|
|
case 'regionType'://地区类型
|
|
$_parent = $parentList->where('key', 'area_cate')->first();
|
|
break;
|
|
case 'politics'://政治面貌
|
|
$_parent = $parentList->where('key', 'political_face')->first();
|
|
break;
|
|
case 'payType'://收支类型
|
|
$_parent = $parentList->where('key', 'money_cate')->first();
|
|
break;
|
|
case 'hygieneType'://卫生检查类型
|
|
$_parent = $parentList->where('key', 'sanitary_inspection')->first();
|
|
break;
|
|
case 'houseHold'://户籍管理
|
|
$_parent = $parentList->where('key', 'domicile')->first();
|
|
break;
|
|
case 'folk'://民族管理
|
|
$_parent = $parentList->where('key', 'nation')->first();
|
|
break;
|
|
case 'eduction'://文化程度
|
|
$_parent = $parentList->where('key', 'educational_level')->first();
|
|
break;
|
|
case 'disputeType'://口头纠纷类型
|
|
$_parent = $parentList->where('key', 'oral_disputes')->first();
|
|
break;
|
|
}
|
|
if($_parent){
|
|
$_keyword = [
|
|
'key' => $_parent->key.$dict->id,
|
|
'name' => $dict->txt,
|
|
'sort' => $dict->sorted,
|
|
'parent_id' => $_parent->id,
|
|
'parent_key'=> $_parent->key,
|
|
'lv' => $_parent->lv+1,
|
|
'path' => $_parent->path.$_parent->id.'-',
|
|
'oid' => $dict->id,
|
|
'created_at'=>now(),
|
|
'updated_at'=>now()
|
|
];
|
|
}
|
|
if($_keyword){
|
|
$newKeywords[$dict->id] = $_keyword;
|
|
}
|
|
}
|
|
|
|
if(count($newKeywords) > 0){
|
|
try {
|
|
DB::begintransaction();
|
|
DB::table('keywords')->insert($newKeywords);
|
|
DB::commit();
|
|
} catch (Throwable $th) {
|
|
DB::rollBack();
|
|
report($th);
|
|
}
|
|
}
|
|
}
|
|
} |