有时为了调试magento,需要获取当前的查询sql语句,在magento中获取SQL语句,这里我们通过
$collection->getSelectSql(true)来调试sql
1 $collection=Mage::getResourceModel('reports/product_collection');
2 $query=$collection->getSelectSql(true);
3 echo $query;
magento获取SQL语句的另外一种方法是设置打印SQL为true
1 $collection=Mage::getResourceModel('reports/product_collection');
2 $collection->printlogquery(true);
得到的SQL语句 :
1 SELECT `e`.* FROM `catalog_product_entity` AS `e`
这里只是打印查询产品的SQL,如果要获取其他地方的SQL语句,道理也是一样的,我们根据上面的sql语句可以看到,其实magento的性能很 差,”select *”,magetno又是基于EAV(Entity Attribute Value)模型架构的,可以想象下这速度
Magento的Models 和Collection 很强大,使用它们可以很方便的查询和操作数据库。开发中,因为一些特殊需求或对Magento的了解不够深,可能会需要自己手写SQL语句来查询和操作数据库。以下分别是读写数据库的代码。
01 // For Read
02 // fetch read database connection that is used in Mage_Core module
03
04 $read= Mage::getSingleton('core/resource')->getConnection('core_read');
05
06 // first way
07 $query = $read->query("select name from core_website");
08 while ($row = $query->fetch())
09 {
10 $row = new Varien_Object($row);
11 echo "<strong>" . $row->getName() . "</strong><br/>";
12 }
13
14 // second way
15 $results = $read->fetchAll("SELECT * FROM core_website;");
16 foreach ($results as $row)
17 {
18 echo $row['name'] . "<br/>";
19 }
1 // For Write
2 // fetch write database connection that is used in Mage_Core module
3 $write = Mage::getSingleton('core/resource')->getConnection('core_write');
4
5 // now $write is an instance of Zend_Db_Adapter_Abstract
6 $write->query("insert into tablename values ('aaa','bbb','ccc')");
注意上面的getConnection()方法中的参数 “core_read”,表明了Magento将要使用的资源。与之相对应,当我们修改数据库的时候使用参数”core_write”.一般情况下 getConnection方法的参数应设成”core_read” 或 “core_write”(应该不指定也是可以的,但是如果Magento有多个数据库就必须指定了)。
作为新的entension module,在config.xml对”core_read” “core_write” 进行定义是个好的习惯。定义如下:
01 <config>
02 <global>
03 <resources>
04 <extension_setup>
05 <connection>
06 <use>core_setup</use>
07 </connection>
08 </extension_setup>
09 <extension_read>
10 <connection>
11 <use>core_read</use>
12 </connection>
13 </extension_read>
14 <extension_write>
15 <connection>
16 <use>core_write</use>
17 </connection>
18 </extension_write>
19 </resources>
20 </global>
21 </config>
对应上面新增的module的名字.使用下面相对应的语句在read或write Database:
1 $conn = Mage::getSingleton('core/resource')->getConnection('extension_read');
2 $conn = Mage::getSingleton('core/resource')->getConnection('extension_write');
一般情况是绝大多数的module都定义成”core_read” “core_write”方便且节省资源。当然特殊情况除外:
给每个module不同的读写权限
需要用多个Database
from: http://blog.sina.com.cn/s/blog_687015bd0100t2b2.html