refactor: 数据迁移
This commit is contained in:
@@ -47,6 +47,12 @@ class DataMigration extends Command
|
|||||||
// 迁移产品
|
// 迁移产品
|
||||||
// $this->migrateProduct();
|
// $this->migrateProduct();
|
||||||
|
|
||||||
|
// $files = $this->getLocalImages('/var/www/html/orico-official-website/public/migrate_temp_images');
|
||||||
|
// print_r($files);
|
||||||
|
// foreach ($files as $file) {
|
||||||
|
// unlink($file);
|
||||||
|
// }
|
||||||
|
|
||||||
// 迁移产品关联产品数据
|
// 迁移产品关联产品数据
|
||||||
// $this->migrateProductRelated();
|
// $this->migrateProductRelated();
|
||||||
|
|
||||||
@@ -128,6 +134,31 @@ class DataMigration extends Command
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 获取本地图片
|
||||||
|
private function getLocalImages($path)
|
||||||
|
{
|
||||||
|
$files = [];
|
||||||
|
$dir = dir($path);
|
||||||
|
while (false !== ($entry = $dir->read())) {
|
||||||
|
if ($entry == '.' || $entry == '..') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$file = $path . '/' . $entry;
|
||||||
|
if (is_dir($file)) {
|
||||||
|
$files = array_merge($files, $this->getLocalImages($file));
|
||||||
|
} else {
|
||||||
|
$info = stat($file);
|
||||||
|
if ($info['size'] == 0) {
|
||||||
|
$files[] = $file;
|
||||||
|
}
|
||||||
|
// if (!is_valid_image($file)) {
|
||||||
|
// $files[] = $file;
|
||||||
|
// }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $files;
|
||||||
|
}
|
||||||
|
|
||||||
// 迁移tco产品分类
|
// 迁移tco产品分类
|
||||||
private function productTcoCategory()
|
private function productTcoCategory()
|
||||||
{
|
{
|
||||||
@@ -266,7 +297,7 @@ class DataMigration extends Command
|
|||||||
|
|
||||||
$products = $old_db->name('product')
|
$products = $old_db->name('product')
|
||||||
->where('country_code', 'in', ['ZH', 'US'])
|
->where('country_code', 'in', ['ZH', 'US'])
|
||||||
->where('id', '>', 0)
|
->where('id', '>', 15789)
|
||||||
->order(['id' => 'asc'])
|
->order(['id' => 'asc'])
|
||||||
->cursor();
|
->cursor();
|
||||||
|
|
||||||
@@ -416,6 +447,7 @@ class DataMigration extends Command
|
|||||||
if ($k == 'Color') $k = '颜色';
|
if ($k == 'Color') $k = '颜色';
|
||||||
$attr_value = '/static/common/images/colors/' . $at . '.png';
|
$attr_value = '/static/common/images/colors/' . $at . '.png';
|
||||||
}
|
}
|
||||||
|
$images[$pkey]['color'] = $at;
|
||||||
$images[$pkey]['attrs'][] = [
|
$images[$pkey]['attrs'][] = [
|
||||||
'attr_id' => $attrs_map[$v['country_code']][$k],
|
'attr_id' => $attrs_map[$v['country_code']][$k],
|
||||||
'attr_value' => $attr_value,
|
'attr_value' => $attr_value,
|
||||||
@@ -458,7 +490,7 @@ class DataMigration extends Command
|
|||||||
|
|
||||||
$two_images = $old_db->name('product_two_img')
|
$two_images = $old_db->name('product_two_img')
|
||||||
->where('product_id', '=', $v['id'])
|
->where('product_id', '=', $v['id'])
|
||||||
->where('country_code', '=', $v['country_code'])
|
// ->where('country_code', '=', $v['country_code'])
|
||||||
->where('stat', '=', 0)
|
->where('stat', '=', 0)
|
||||||
->order(['id' => 'asc'])
|
->order(['id' => 'asc'])
|
||||||
->select();
|
->select();
|
||||||
@@ -494,6 +526,19 @@ class DataMigration extends Command
|
|||||||
$temp_images = [];
|
$temp_images = [];
|
||||||
foreach ($skus as $idx => $sku) {
|
foreach ($skus as $idx => $sku) {
|
||||||
$skus[$idx]['product_id'] = $id;
|
$skus[$idx]['product_id'] = $id;
|
||||||
|
foreach ($images as $im) {
|
||||||
|
if (isset($im['color'])) {
|
||||||
|
if (md5($im['color']) == $sku['pkey']) {
|
||||||
|
$skus[$idx]['sku'] = $im['sku']??null;
|
||||||
|
$skus[$idx]['photo_album'] = $im['photo_album']??null;
|
||||||
|
if (!empty($im['attrs'])) {
|
||||||
|
$skus[$idx]['attrs'] = $im['attrs'];
|
||||||
|
}
|
||||||
|
continue 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (isset($images[$sku['pkey']])) {
|
if (isset($images[$sku['pkey']])) {
|
||||||
$skus[$idx]['sku'] = $images[$sku['pkey']]['sku']??null;
|
$skus[$idx]['sku'] = $images[$sku['pkey']]['sku']??null;
|
||||||
$skus[$idx]['photo_album'] = $images[$sku['pkey']]['photo_album']??null;
|
$skus[$idx]['photo_album'] = $images[$sku['pkey']]['photo_album']??null;
|
||||||
|
|||||||
Reference in New Issue
Block a user