标签:mysql magento database-migration magento-1-4
我在旧的在线商店拥有超过300,000名用户.客户端切换到Magento解决方案,现在必须将所有用户,地址迁移到Magento.所以我必须编写一个自定义脚本来将用户及其地址导入Magento系统.
是否已经完成了任何教程或类似的工作.请帮我.
谢谢
解决方法:
下面是我如何使用SOAP库将用户从OSC迁移到Magento的示例.这个脚本在旧服务器上运行,需要从ssh命令行运行(php执行时通过浏览器不支持这个
$proxy = new SoapClient('http://[your magento url]/api/soap/?wsdl=1');
$sessionId = $proxy->login('admin', '[your password]');
// connect to local db
$link = mysql_connect('localhost', '[old ecommerce db]', '[old db pw]');
if (!$link) {
die('Could not connect: ' . mysql_error());
}
mysql_select_db('sbc_osc', $link);
$sql = "SELECT * FROM customers";
$customers = mysql_query($sql);
// loop thyrough customers
while ($customer = mysql_fetch_assoc($customers)) {
set_time_limit(600);
$newCustomer = array(
'firstname' => $customer['customers_firstname'],
'lastname' => $customer['customers_lastname'],
'email' => $customer['customers_email_address'],
'password_hash' => $customer['customers_password'],
'store_id' => 2, // set the store you want to send to
'website_id' => 2
);
$telephone = $customer['customers_telephone'];
$fax = $customer['customers_fax'];
try{
$newCustomerId = $proxy->call($sessionId, 'customer.create', array($newCustomer));
}
catch (Exception $e) {
echo "failed to create customer for: " . $customer['customers_firstname'] . " " . $customer['customers_lastname'] . "\n";
}
// grab the default address
$sql = "SELECT ab.*, c.countries_iso_code_2, z.zone_name, z.zone_id
FROM address_book ab
LEFT JOIN countries c ON ab.entry_country_id = c.countries_id
LEFT JOIN zones z ON ab.entry_zone_id = z.zone_id
WHERE customers_id = {$customer['customers_id']} AND address_book_id = {$customer['customers_default_address_id']}";
$addresses = mysql_query($sql);
while ($address = mysql_fetch_assoc($addresses)) {
$newCustomerAddress = array(
'firstname' => $address['entry_firstname'],
'lastname' => $address['entry_lastname'],
'company' => $address['entry_company'],
'country_id' => $address['countries_iso_code_2'],
'region_id' => $address['zone_id'],
'region' => ($address['zone_name'] != "" ? $address['zone_name'] : $address['entry_state']),
'city' => $address['entry_city'],
'street' => array($address['entry_street_address']),
'telephone' => $telephone,
'fax' => $fax,
'postcode' => $address['entry_postcode'],
'is_default_billing' => true,
'is_default_shipping' => true,
);
try{
$newAddressId = $proxy->call($sessionId, 'customer_address.create', array($newCustomerId, $newCustomerAddress));
}
catch (Exception $e) {
echo "failed to add address for: " . $address['entry_firstname'] . " " . $address['entry_lastname'] . "\n";
}
}
echo "migrated: " . $customer['customers_firstname'] . " " . $customer['customers_lastname'] . "\n";
}
mysql_close($link);
你需要注意的一件事是密码..为了工作,我必须设置Magento使用相同的密码散列模式.
标签:mysql,magento,database-migration,magento-1-4 来源: https://codeday.me/bug/20190626/1297528.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。