Magento api(API接口): http://devdocs.magento.com/guides/m1x/api/soap/catalog/catalog.htmlphp
Magento module creator(快速建立): http://www.silksoftware.com/magento-module-creator/html
$count = 5;sql
$offset = 0;數據庫
$category = Mage::getModel('catalog/category')->load($categoryId);api
$collection = Mage::getModel('catalog/product')->getCollection()app
->addAttributeToSelect('*')frontend
->addCategoryFilter($category) //獲取指定類目的產品ide
->addAttributeToFilter('type_id', Mage_Catalog_Model_Product_Type::TYPE_CONFIGURABLE) //config productfetch
->addAttributeToFilter('status',1) //enable productui
->setOrder("updated_at","DESC"); //order by updataed_at desc
$collection->getSelect()->limit($count,$offset); //limit, from $offset, get $count products
foreach($collection as $product){
echo $product->getId() . PHP_EOL;
}
if($_product = Mage::getModel('catalog/product')->loadByAttribute('sku','44025040956')){
if($_product->isConfigurable()){
$allProducts = $_product->getTypeInstance(true)->getUsedProducts(null, $_product);
foreach($allProducts as $simpleProduct){
echo $simpleProduct->getId() . PHP_EOL;
}
}
echo $_product->getId() . PHP_EOL;
}
$product = Mage::getModel('catalog/product')->load($id);
$product = Mage::getModel('catalog/product')->loadByAttribute('sku',$sku);
$limit = 5;//獲取5條信息
$collection = Mage::getModel('catalog/product')->getCollection();
$collection->getSelect()->limit(5)->order(new Zend_Db_Expr('RAND()'));
注:在model/resource裏
$conn = Mage::getSingleton("core/resource")->getConnection('core_read');
已經定義好了,$conn == $this->_getReadAdapter(). 一樣也有$this->_getWriteAdapter()
如:Mage::getModel('newaddproducts/newaddproducts')->getResource()->getList()
第一種:
$conn = Mage::getSingleton("core/resource")->getConnection('core_read');
$sql = 「select * from AA」;
$conn->fetchAll($sql); //查詢多條記錄
$conn->fetchRow($sql);//查詢一條記錄
$conn->query($sql); //執行sql語句(添加/修改/刪除)
第二種:
如表log_product_sync,有字段taobaoid,status,info,其中taobaoid爲主鍵,則:
$arrData = array(
'taobaoid' => $id,
'status' => '11',
'info' => ‘test’
);
$conn = Mage::getSingleton("core/resource")->getConnection('log_read');
添加:$conn->insert('log_product_sync', $arrData);//成功返回1
修改:$conn->update('log_product_sync',$arrData,array('status = ?' => '11'));
執行:$conn->query($sql);
查詢一條記錄:
$bind = array('type'=>$type,'taobaoid'=>$tbId);
$select = $conn->select()->from('taobao_newadd')->where('type = :type and taobaoid = :taobaoid')->order('timestamp desc');
$data = $conn->fetchRow($select,$bind);
第三種:
//添加
$model = Mage::getModel("imgprocess/imgprocess")
->setData($data)
->save();
//修改
$model = Mage::getModel("imgprocess/imgprocess")
->addData($data)
->setId($id) //$id 爲主鍵
->save();
//查詢
$info = Mage::getModel("imgprocess/imgprocess")->load($id);
//刪除
Mage::getModel("imgprocess/imgprocess")->load($id)->delete();
$skeletonId = 4;
$setId=Mage::getModel("catalog/product_attribute_set_api")->create($setName, $skeletonId);
$data = array(
"attribute_code" => 'customs_attribute_name',
"frontend_input" => "select",
"scope" => "global",
"is_unique" => 0,
"is_required" => 0,
"apply_to" => array("simple", "grouped", "configurable"),
"is_configurable" => 1,
"is_filterable"=>2,
"is_searchable" => 1,
"is_visible_in_advanced_search" => 0,
"is_comparable" => 0,
"is_used_for_promo_rules" => 1,
"is_visible_on_front" => 0,
"used_in_product_listing" => 0,
"additional_fields" => array(),
"frontend_label" => array(array("store_id" => "0", "label" => 'attribute_name'))
);
$attribute_id = Mage::getModel("catalog/product_attribute_api")->create($data);
$result = Mage::getModel("catalog/product_attribute_set_api")->attributeAdd($attribute_id, $attribute_set_id);
$data = array(
"label" => array(
array("store_id" => array("0"), "value" => $option_name)
),
"order" => "",
"is_default" => "0"
);
Mage::getModel("catalog/product_attribute_api")->addOption($attribute_id, $data);
$options = Mage::getModel("catalog/product_attribute_api")->options($attribute_id);
$attributes = Mage::getModel('catalog/product')->getResource()
->loadAllAttributes()
->getSortedAttributes($set_id);
$data = Mage::getModel('catalog/resource_eav_attribute')->load($attribute_id)->getData();
$order = Mage::getModel("sales/order")->load(219);//orderId:219, order incrementId:100000219
$itemQty = $order->getItemsCollection()->count();
$shipment = Mage::getModel('sales/service_order', $order)->prepareShipment($itemQty);
$shipment = new Mage_Sales_Model_Order_Shipment_Api();
$shipmentId = $shipment->create($order->getData('increment_id'));
var_dump($shipmentId);
if ($shipmentId){// $shipmentId is like 100000008,real shipment_id maybe is 8
$CarrierCode = 'custom';
$TrackingTitle = "title";
$TrackingNumber= "num001";
$TrackId=Mage::getModel('sales/order_shipment_api')->addTrack($shipmentId, $CarrierCode, $TrackingTitle, $TrackingNumber);
}
var_dump($TrackId);
//get shipment by shipment_id
$shipmentId = 7;
$shipment = Mage::getModel('sales/order_shipment')->load($shipmentId);
//get shipment by shipment increment_id
$shipmentIncId = '100000007';
$shipment = Mage::getModel('sales/order_shipment')->loadByIncrementId($shipmentIncId);
var_dump($shipment->getData());
$item = Mage::getModel('bucket/package_item')->getCollection()
//->addAttributeToSelect('*')
->addFieldToFilter('order_item_id','963')->getFirstItem();
var_dump($item->getData());
<?php
require_once 'app/Mage.php';
Mage::setIsDeveloperMode(true);
Mage::app('admin');
ini_set('display_errors', 1);
umask(0);
header('Content-Type: text/xml');
echo $config = Mage::getConfig()->loadModulesConfiguration('system.xml')->getNode()->asXML();
echo Mage::getStoreConfig('trans_email/ident_sales/email');
$currencyCode = Mage::app()->getStore()->getCurrentCurrencyCode();
$symbol = Mage::app()->getLocale()->currency($currencyCode)->getSymbol();
//轉換貨幣
$baseCurrencyCode = Mage::app()->getStore()->getBaseCurrencyCode();
$currentCurrencyCode = Mage::app()->getStore()->getCurrentCurrencyCode();
Mage::helper('directory')->currencyConvert($price(),$baseCurrencyCode,$currentCurrencyCode);
一、 文本類型
$installer = new Mage_Eav_Model_Entity_Setup('core_setup');
$installer->startSetup();
$attribute = array(
'type' => 'varchar',
'label'=> 'My Text',
'input' => 'text',
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
'visible' => true,
'required' => false,
'user_defined' => true,
'default' => "",
'group' => "General Information"
);
$installer->addAttribute('catalog_category', 'my_text', $attribute);
$installer->endSetup();
二、 圖片類型
$installer = new Mage_Eav_Model_Entity_Setup('core_setup');
$installer->startSetup();
$attribute = array(
'type' => 'varchar',
'label'=> 'Mobile Image',
'input'=> 'image',
'backend'=> 'catalog/category_attribute_backend_image',
'required'=> false,
'sort_order'=> 5,
'global'=> Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_STORE,
'group'=> 'General Information'
);
$installer->addAttribute('catalog_category', 'mobile_image', $attribute);
$installer->endSetup();
$product = Mage::getModel('catalog/product')->load('123');
if($product->isConfigurable()){//config product
$allProducts = $product->getTypeInstance(true)->getUsedProducts(null, $product);
$singleStock = 0;
foreach($allProducts as $simpleProduct){
if(empty($simpleProduct->getIsInStock())){
$singleStock++;
}
}
if(count($allProducts) == $singleStock){
echo 'out stock';
}
}else{//single product
if(empty($product->getIsInStock())){
echo 'out stock';
}
}
1\ use model
$url = "zymen-men-s-stretch-custom-fit-business-casual-suit-pants-235909.html";
$rewriteInfo = Mage::getModel('core/url_rewrite')->setStoreId(1)->loadByRequestPath($url);
var_dump($productRewrite->getData());
//array(10) { ["url_rewrite_id"]=> string(7) "1079437" ["store_id"]=> string(1) "1" ["id_path"]=> string(19) "80656800_1503557722" ["request_path"]=> string(69) "zymen-men-s-stretch-custom-fit-business-casual-suit-pants-235909.html" ["target_path"]=> string(69) "zymen-men-s-stretch-custom-fit-business-casual-suit-pants-235910.html" ["is_system"]=> string(1) "0" ["options"]=> string(2) "RP" ["description"]=> NULL ["category_id"]=> NULL ["product_id"]=> string(6) "235909" }
2\ use conn and get it's final url
$conn = Mage::getSingleton("core/resource")->getConnection('core_read');
function getTargetPath($conn,$requestPath){
if(empty($requestPath)){
return false;
}
if($row = $conn->fetchRow("select request_path,target_path,is_system from core_url_rewrite where request_path = '".$requestPath."' and store_id=1")){
if(empty($row['is_system'])){
echo '1-';
return getTargetPath($conn,$row['target_path']);
}else{
echo '2-';
return $row['request_path'];
}
}
}
$url = "zymen-men-s-stretch-custom-fit-business-casual-suit-pants-235909.html";
$rewriteUrl = getTargetPath($conn,$url);
var_dump($rewriteUrl);
//1-2-string(69) "zymen-men-s-stretch-custom-fit-business-casual-suit-pants-235910.html"
錯誤提示大概是這樣的
Integrity constraint violation: 1052 Column 'increment_id' in where clause is ambiguous
使用 代碼 'filter_index'=>'main_table.increment_id', 能夠解決這個問題
解決方法例子代碼以下:
$this->addColumn('real_order_id', array(
'header'=> Mage::helper('sales')->__('Order #'),
'width' => '80px',
'type' => 'text',
'index' => 'increment_id',
'filter_index'=>'main_table.increment_id',//use which table column
));
<?php echo Mage::helper("adminhtml")->getUrl("*/*/getproductlist");?>
<?php echo $this->getUrl('*/*/updateProduct'); ?>
get
$productId = 478509;
$product = Mage::getModel('catalog/product')->load($productId);
var_dump($product->getCategoryIds());
//array(5) { [0]=> string(1) "1" [1]=> string(1) "2" [2]=> string(2) "27" [3]=> string(2) "28"}
set
$productId = 478509;
$catalogId = 28;
if($catalogPath = Mage::getModel('catalog/category')->load($catalogId)->getPath()){
$catalogIds = explode('/',$catalogPath);//$catalogPath = '1/2/27/28'
if(!empty($catalogIds)){
$product = Mage::getModel('catalog/product')->load($productId);
$product->setCategoryIds($catalogIds);
$product->save();
return true;
}
}
Mage::getStoreConfig('general/locale/code', $storeId)
like: en_US , es_ES ...