Banner - Blog zu den Themen Programmierung, SEO, SEM, Social Media, Internet Marketing, Webdesign, IT-Service und Mehr - SEO Hannover - IT-Dienstleistungen und SEO Agentur Fly2Mars-Media.de

Archiv

Archiv für die Kategorie ‘MySQL’

Magento / Import in MySQL 5.0 – USING BTREE Error

19. November 2010 2 Kommentare

Wenn ihr ein MySQL-Datenbank-Dump in eine MySQL 5.0 importieren möchtet welche mit mysqldump auf einer 5.1 erzeugt wurde, dann bekommt ihr höchstwahrscheinlich eine Fehlermeldung wie die folgende:

Der Grund ist dass die key syntax von 5.0 auf 5.1 wie folgt geändert wurde:
mysql50
UNIQUE KEY IDX_BASE( entity_type_id, entity_id, attribute_id, store_id ) USING BTREE,
mysql51
UNIQUE KEY IDX_BASE USING BTREE ( entity_type_id, entity_id, attribute_id, store_id ),

Leider gibt es kein aktuellen Kompatabilitäts-Modus like –comptability=mysql50 in mysqldump.
Es kann zwar mysqldump –comptability=mysql40 benutzt werden, allerdings auf eigene Gefahr ;-)

Mit dem folgenden Befehl könnt ihr in der Bash den dump vor dem Import bereinigen (benutzt das consolen-programm “sed”):

sed -i -r 's/\(([^)]+)\) USING BTREE/USING BTREE (\1)/g' magento.sql
KategorienMagento, MySQL Tags: , ,

MySQL Backup schneller importieren

Problem

Falls ihr größere Backups habt, welche z.B. mit mysqldump erstellt wurden, so kann der komplette Import schon mal einige Minuten dauern.  Was die Meisten nicht wissen ist, dass der Import solcher mit mysqldump erstellten Backup Dateien viel länger dauert.

How Can I Speed Up This Process?

Bei setzen der folgenden Flags vor dem Import im Datenbank Dump, kann die Importzeit dramatisch verkürzt werden:

SET autocommit=0;
SET unique_checks=0;
SET foreign_key_checks=0;

Wenn der auto-commit deaktiviert wurde muss am Ende ein manueller commit erfolgen:

COMMIT;

Durch deaktivieren der unique checks und foreign key kann einiges an Geschwindigkeit heraus geholt werden.

Mit dem folgenden Bash-Script könnt ihr das Szenario automatisieren:

#!/bin/bash
echo "SET autocommit=0;
SET unique_checks=0;
SET foreign_key_checks=0;" > backup.sql
mysqldump -u myuser --password=mypassword mydatabase >> backup.sql
echo "COMMIT;" >> backup.sql
KategorienMySQL Tags: , , ,

MySQL Datenbank Import ERROR 2006 (HY000) – MySQL Server has gone away – Lösung

Wenn ihr beim Import eines MySQL-Datenbank-Dumps folgende Fehlermeldung erhaltet:

ERROR 2006 (HY000) at line XXX: MySQL server has gone away

dann könnt ihr das durch setzen der “max_allowed_packet = 1M” von 1MB zu “max_allowed_packet = 32M” lösen.
und zwar unter dem Abschnitt mysqld in der my.ini, also:

[mysqld]
max_allowed_packet=32M
KategorienMySQL Tags: , , ,

Reverse Engineering mit MySQL Workbench MySQL Workbench

23. Dezember 2009 Keine Kommentare

Zur grafisch Erstellung einer MySQL Datenbanken wird das kostenlose Programm MySQL Workbench bereit gestellt. Ebenfalls ist Reverse Engineering möglich, ihr könnt ein Datenbankmodel aus einer bestehenden Datenbank Tabelle generieren und editieren.

Ihr habt bereits eine Tabelle die ihr anpassen möchtet? Kein Problem, neben dem editieren um z.B. Erweiterung einzubauen, könnt ihr Fremdschlüsseln zuweisen. Nach dem laden der Datenbank habt ihr sofort euer Datenbankmodel und könnt dieses Bequem mit einer grafischen Oberfläche erweitern. Die Fremdschlüssel werden so gar automatisch durch das Setzen von Verbindungen generiert.

MySQL Workbench

MySQL Repair – Error Codes

12. November 2009 Keine Kommentare

Gelegentlich erhaltet ihr MySQL-Errors bei einem Repair von Tabellen … hier findet ihr eine kurze Übersicht einiger Error-Codes sowie Hinweise zum lösen. Anhand der Error-Codes kann z.B. abgeleitet werden ob der Fehler von einem defekten Datei-System hervor geht, es gar ein MySQL-Bug ist oder ähnlich. Nicht verzweifeln, sondern genau die Fehler-Codes analysieren!

Magento Resources – Coding Tipps – Magento Cheat Sheet – Magento Hints

php-code

Eine MySQL Datenbank kopieren als Linux Root

Mit dem folgendem Befehlt könnt ihr erfolgreich eine Magento Datenbank kopieren:

$ mysqldump -u root –password=pass db1 | mysql -u root –password=pass db2

Aktuelle Store ID abfragen

Manchmal ist es notwendig die aktuelle Store-ID abzufragen, das geht wie folgt:

Mage::app()->getStore()->getCode()

Aktuelles Land des gewählten Stores ausgeben / get current country of the selected store in Magento

    public function getStoreCountry()
    {
    	return Mage::getStoreConfig('general/country/default', Mage::app()->getStore()->getId());
    }

Heraus finden ob ein Benutzer am System angemeldet ist

Das ist wirklich nützlich wenn Sie z.B. eine spezielle Nachricht oder Gutschein-Code nur für eingeloggte Kunden anzeigen wollen

Mage::getSingleton( 'customer/session' )->isLoggedIn()

Blocks anzeigen welche in dem Bereich nicht geladen sind (Template)

In dem Beispiel binden wir die Top-Suche außerhalb der header.phtml ein. Sie können die Methode überall in den Template-Dateien aufrufen, um Blücke anzuzeigen welche an der Stelle nicht geladen werden.

$this->getChildHtml()
<?php echo $this->getLayout()->getBlock('top.search')->toHtml()?>

Ein bestimmtes Attribut ausgeben

Um den Namen eines Attributes in einer Bestellung anzuzeigen, folgenden Code aufrufen (z.B. in template/catalog/product/view.phtml ):

 <?php echo $_product->getAttributeText('furniture_type') ?> 

Wie gibt man den aktuellen Layout Ordner (theme folder) ausgeben?

 <?php echo $this->getSkinUrl('') ?> 

Die Ausgabe ist ähnlich: http://www.yoursite.com/skin/frontend/default/default/

Warum das sinnvoll ist:
Falls Sie ein neuen CSS Style hinzufügen wollen um z.B. ein Hintergrundbild anzuzeigen, ist der Beste Weg dieses in das Ihr Template Bilder Ordner zu packen und eine Referenz über diesen Aufruf zu setzen:

.className {
background-image: url( }

Oder eine JavaScript Datei einzubinden:

<script type="text/javascript" src="<?php echo $this->getSkinUrl('js/Script.js')?>">

Abfrage von Daten aus der Datenbank (ohne SQL-Abfrage)

Einige Module haben ein Resoure-Model definiert, über das Ihr Daten direkt von der Datenbank abfragen könnt (mapping). Der Zugriff erfolgt in der Regel dann für die Spalte xy über das die Methode getXy() des Models.

Abfrage von Daten aus der Datenbank (per SQL-Abfrage)

Im Rahmen der Entwicklung von Erweiterungen ist es ggf. notwendig Daten aus der Datenbank abzufragen.
Da Magento auf das ZendFramework basiert, ist der Aufruf identisch und zwar wie folgt:

$select = '';
$table = 'table_name';
$where = 'id=' . $id;
$order = '';
// read data
$connection = Mage::getSingleton('core/resource')
->getConnection('core_read');
$select = $connection->select()
->from($table)
->where($where)
->order($order);
$data = $connection->fetchAll($select);

Session Variable in Magento setzen und abfragen

Mage::getSingleton('core/session')->setYourVariable('data');
 $Data = Mage::getSingleton('core/session')->getYourVariable();

Hier noch eine Übersicht von diversen häufig gebrauchten Funktionen (wird zukünftig noch erweitert):

Diverse Werte

<?php
$storeId     = Mage::app()->getStore()->getId();
$storeName   = Mage::app()->getStore()->getName();
$storeCode   = Mage::app()->getStore()->getCode();
$groupId     = Mage::app()->getStore()->getGroupID();
$groupName   = Mage::app()->getStore()->getGroup()->getName();
$websiteName = Mage::app()->getWebsite()->getName();

Models

<?php
$customer = Mage::getModel('customer/customer');
$order    = Mage::getModel('sales/order');
$product  = Mage::getModel('catalog/product');
/* own modul in local */
Mage::getModel('namespace_modul/model')->init($item);

Blocks

<?php
$block = Mage::app()->getLayout()->createBlock('Namespace_Module_Block_BlockName');

Helpers

<?php
$helper = Mage::helper('helper');

Logging

<?php
Mage::log('Schreibe das ins Logfile');

Globale Variable setzen & auslesen

Globale Variable in Magento definieren:

Mage::register('globaleVariable', 'Inhalt');
Mage::log('log-message', Zend_Log::DEBUG, 'logefile.log');

Globale Variable in Magento auslesen:

Mage::registry('globaleVariable');

Globale Variable in Magento löschen:

Mage::unregister('globaleVariable');

Website ID anzeigen (website_id)

<?php echo  Mage::app()->getWebsite()->getID(); ?>

StoreGroup ID anzeigen (group_id)

<?php echo  Mage::app()->getStore()->getGroupID(); ?>

Website Name anzeigen (name)

<?php echo  Mage::app()->getWebsite()->getName(); ?>

Store Name anzeigen (name)

<?php echo  Mage::app()->getStore()->getGroup()->getName(); ?>

StoreView Name anzeigen (name)

<?php echo  Mage::app()->getStore()->getName(); ?>

Skin URL

<?php echo $this->getSkinUrl('images/test.jpg')  ?>

SKU anzeigen

<?php echo  $this->htmlEscape($_product->getSku()) ?>

Hersteller anzeigen

<?php echo  $_product->getAttributeText('manufacturer') ?>

Link zur anzeige einer Kategorie erzeugen

// die Zahl bei load() ist die Category-ID
Mage::getModel('catalog/category')->load('1000')->getUrl();

Link zu einem bestimmen Pfad erzeugen

$this->getUrl('checkout/cart/')

Alternativ

Mage::getBaseDir('lib');  // lib folder
Mage::getBaseDir('media'); // media folder

die aktuelle Action (ActionName) auslesen

// liefert als return zB. &quot;new&quot;
$this->getRequest()->getActionName());

den aktuellen Controller (ControllerName) auslesen

// liefert als return zB. &quot;catalog&quot;
$this->getRequest()->getControllerName());

Module überschreiben (config.xml)

Wenn ihr ein Model überschreiben möchtet so sieht dazu die Config wie folgt aus. Hier am Beispiel des Catalog Model Mage_Catalog_Model_Config welches durch die neu angelegte Klasse Namespace_Catalog_Model_Config erweitert wird, welche im neu angelegten Module Ordner unter /app/code/local/Namespace/Catalog/Model/Config.php abgelegt ist ):

<?xml version=&quot;1.0&quot;?>
<config>
 <modules>
 <Namespace_Catalog>
 <version>0.0.1</version>
 </Namespace_Catalog>
 </modules>
 <global>
 <models>
 <catalog>
 <rewrite>
 <config>Namespace_Catalog_Model_Config</config>
 </rewrite>
 </catalog>
 </models>
 </global>
</config>

Magento: Alle aktiven Sprachen anzeigen / show Available Languages

$availLangs = Mage::getStoreConfig('general/locale/available_languages');
 if (!is_array($availLangs)) {
 $availLangs = explode(',', $availLangs);
 }

Magento: Liste aller verfügbaren Länder / show list of available countries

if (!$countryCollection) {
$countryCollection = Mage::getModel('directory/country_api')->items();
}
foreach($countryCollection as $country) {
var_dump($country);
}

Magento: Filter Attribute erweitern / entfernen (Filter List on Product/Category/Search List)

// $this = Mage_Catalog_Block_Product_List_Toolbar
$this->addOrderToAvailableOrders('price', $this->__('Price'));
// $this = Mage_Catalog_Block_Product_List_Toolbar
// remove attribute
$this->removeOrderFromAvailableOrders('price');

Im Editor Path setzen

{{store direct_url='datenschutzerklaerung'}}

Get the current category name in Magento / Aktuellen Kategorie Namen in Magento ausgeben

Mage::registry('current_category')->getName();

Get the current category in Magento / Aktuellen Kategorie in Magento

Mage::registry('current_category');

Get the current category level in Magento / aktuell Ebene der Kategorie in Magento ausgeben

$currCat = Mage::registry('current_category');
echo $currCat->getLevel();

Display all sub-categories from the actual category in Magento / Unterkategorien der aktuellen Kategorie anzeigen in Magento ausgeben

$currCat = Mage::registry('current_category');
$_categories = Mage::getModel('catalog/category')->getCategories($currCat->getEntityId());
foreach($_categories as $_category)
	echo $_category->getName();

Get Request Param

$this->getRequest()->getParam('website');

Daten auslesen / Filtern / Collection / getResourceModel

$collection = Mage::getResourceModel('sales/order_collection')
 ->addFieldToSelect('grand_total')
 ->addFieldToFilter('customer_id', Mage::getSingleton('customer/session')->getId());
 $collection->load();
 return $collection->getSize();

Index Management – Reindex starten aus php-script

// e.g. for flat-catalog 1
$mageFilename = '../app/Mage.php';
require_once $mageFilename;
$indexer = Mage::getSingleton('catalog/product_flat_indexer')->rebuild(1);

den Aktuell Block im Layout / Template ausgeben – get the current block name in layout

$this->getNameInLayout()

Variable von z.b. controller an Template übergeben

Variable definieren

// load xml layout
 $this->loadLayout();
 // load layout block
 $this->getLayout()
 ->getBlock('block_name')
 ->setVariableName($value);

im template ruft ihr die variable ab mit

$this->getVariableName();

Zugriff auf die Config (config values in core_config_data table)

// e.g. the cookie domain value - enter the &quot;path&quot;-value from the &quot;core_config_data table&quot; in the database
Mage::getStoreConfig('web/cookie/cookie_domain')

Dabei ist egal ob die Paramter in der Datenbank oder in der config.xml hinterlegt ist.

Um die folgenden Werte aus der config.xml auszulesen …

<default>
<code>
<value>asdf</value>
</code>
</default>

… verwendet diesen PHP-Snipped:

Mage::getStoreConfig('appcode/value');

die aktuelle Action (ActionName) auslesen

// liefert als return zB. &quot;new&quot;
$this->getRequest()->getActionName());

Link in einer CMS-Page setzen

// z.b. zur Kontakt-Seite
{{store url='contacts'}}

load parent category by product id / Hauptkategorie anhand der Produkt ID laden in Magento

if(!empty($_product)) {
$_categories = Mage::getModel('catalog/product')
->load($_product)
->getCategoryCollection()
->addAttributeToSelect('name')
->addAttributeToFilter('level', 2);
foreach ($_categories as $_category) {
// get parent category name
echo Mage::getModel('catalog/category')->load($_category->getId())->getName();
// get parent category id
echo Mage::getModel('catalog/category')->load($_category->getId())->getId();
}
}

load current currency code in magento / aktuelle Währungs Kürzel des Stores in Magento auslesen

$baseCurrencyCode = Mage::app()->getStore((int)$this->getParam('store'))->getBaseCurrencyCode();

The current url of the page you are in magento / die aktuelle Seiten URL in Magento

$currentUrl = $this->helper('core/url')->getCurrentUrl();

function to get the real country name of a country-code (e.g. ‘gb’) set in store-view as code

	public function get_country_name()
	{
		// Mage::app()->getWebsite()->getCode() is 'gb'
                $collection = Mage::getModel('directory/country')->loadByCode(Mage::app()->getWebsite()->getCode());
		return Mage::app()->getLocale()->getCountryTranslation($collection->getId());
	}

get country name for country code (e.g. ‘gb’ or ‘de’)

$countryName = Mage::getModel('directory/country')->load('gb')->getName();

Attribute & Entity hinzufügen, EAV-Model erweitern in Magento

Ausführliche Infos zu diesem Punkt im Magento Wiki

get product type in Magento

$_product->getTypeId();

isXmlHttpRequest

// $this = Mage_Core_Controller_Request_Http
$this->getRequest()->isXmlHttpRequest();

Getting the Secure (HTTPS) url for Magento

// first opportunity
Mage::getUrl('datacargofactory', array('_secure'=>true)
// second opportunity about the config
Mage::getStoreConfig('web/secure/base_url')

Check Magento Shop Url is Currently Secure

// return true or false
Mage::app()->getStore()->isCurrentlySecure();

Add customer attribute in Magento

$customer = Mage::getModel('customer/customer')->load($customerId);
$customer->setAttributeName($value);
$customer->save();

get current time in Magento / aktuelle Zeit in Magento

$now = Mage::getModel('core/date')->timestamp(time());

get products collection by category in Magento

$productCollection = Mage::getResourceModel('catalog/product_collection')
->addCategoryFilter($category);

show sql select statement from collection

$collection->getSelect()->__toString();

get magento root path / magento root pfad ausgeben

echo Mage::getRoot();

get magento base path / magento base pfad ausgeben

echo Mage::getBaseDir();

load magento store view / magento store view laden

 Mage::app()->getStore()->load(0);

load customer greater than customer_id 5 / magento Kunden laden ab Kunden-ID 5

                $customerItemsCollection = Mage::getModel('customer/customer')->getCollection()
                    ->addAttributeToFilter('entity_id', array('gt' => 5))
                    ->getAllIds();

get magento store url

Mage::getBaseUrl(Mage_Core_Model_Store::URL_TYPE_WEB)

save current product url in session / get current product url

$productId  = (int) $this->getRequest()->getParam('id');
$product    = Mage::getModel('catalog/product')->load($productId);
if($productId != '' && !empty($product)) {
Mage::getSingleton('customer/session')->setBeforeReviewRegUrl($product->getProductUrl());
}

beliebige tempaltes einbinden über xml config files in Magento

<fly2mars_catalog_order>
<remove name="right"/>
<remove name="left"/>
<reference name="root">
<action method="setTemplate"><template>page/1column.phtml</template></action>
</reference>
<reference name="content">
<block type="core/template" name="catalog.order" template="fly2mars/catalog/order.phtml"/>
</reference>
</fly2mars_catalog_order>
<fly2mars_newsletter_subscribe>
<remove name="right"/>
<remove name="left"/>
<reference name="root">
<action method="setTemplate"><template>page/1column.phtml</template></action>
</reference>
<reference name="content">
<block type="core/template" name="catalog.order" template="fly2mars/newsletter/subscribe.phtml"/>
</reference>
</fly2mars_newsletter_subscribe>

alternativ  nur einbinden einer phtml-datei in den header

<default>
<reference name="head">
<block type="core/template" name="marin_tracking" template="fly2mars/tracking.phtml" />
</reference>
<default>

get cms/page collection with filter in magento /cms/page collection mit filter in magento abfrage

$this->_cmsPaqgesCollection = Mage::getModel('cms/page')->getCollection()->addStoreFilter(Mage::app()->getStore()->getId());
$this->_cmsPaqgesCollection->getColumnValues('page_id');
$this->_cmsPaqgesCollection->getColumnValues('title');
$this->_cmsPaqgesCollection->getSelect()->where('page_id=5' );
foreach ($this->_cmsPaqgesCollectiona as $page) {
$PageData = $page->getData();
}

Cheet Sheets für Web-Entwickler

Hier findet ihr ein paar nützliche Cheet-Sheets für Web-Entwickler für HTML, XHTML, CSS, Apache, mod_rewrite, reguläre Ausdrücke, Java-Script, MySQL, Smarty und Jquery.

Magento: Nach Datenbank-Import Fehlermeldung im Front-End

22. Oktober 2009 1 Kommentar

Notice: Undefined index:  0  in /var/www/…/httpdocs/app/code/core/Mage/Core/Model/Mysql4/Config.php on line 92

#0 /var/www/…/httpdocs/app/code/core/Mage/Core/Model/Mysql4/Config.php(92): mageCoreErrorHandler(8, ‘Undefined index…’, ‘/var/www/…’, 92, Array)
#1 /var/www/…/httpdocs/app/code/core/Mage/Core/Model/Config.php(268): Mage_Core_Model_Mysql4_Config->loadToXml(Object(Mage_Core_Model_Config))
#2 /var/www/…/httpdocs/app/code/core/Mage/Core/Model/App.php(263): Mage_Core_Model_Config->init(Array)
#3 /var/www/…/httpdocs/app/Mage.php(434): Mage_Core_Model_App->init(”, ‘store’, Array)
#4 /var/www/…/httpdocs/app/Mage.php(455): Mage::app(”, ‘store’, Array)
#5 /var/www/…/httpdocs/index.php(79): Mage::run(”)
#6 {main}

Ihr habt ein Magento-Backup wieder in eine Datenbank importiert und bekommt beim Aufruf des Shops über das Front-End eine ähnliche Fehlermeldung?

Magento speichert bei der Installation die Website-IDs in die Datenbank mit der ID 0. Bei dem Import oder der Übertragung der Datenbank in eine Andere ist ggf. aus der ID 0 für den Admin-Teil der Website eine 2 geworden (so bei uns im aktuellen Fall).

Ändert ihr nun in der Tabelle core_website und core_store die website_id des Datensatzes mit dem Code admin zurück in eine 0, so ist der Fehler behoben.

Unabhängig davon auch beim Import den Fremdschlüssel-Check deaktivieren wie diesem Artikel beschrieben.

Magento MySQL Datenbank Shema

Das aktuelle Magento Datenbank Shema findet ihr unter

www.magentocommerce.com/wiki/development/magento_database_diagram

Magento: Datenbank importieren – Fehlermeldung vermeiden

Der Import eines Datenbank-Dumb von Magento bricht mit einer Fehlermeldung ab oder wird nicht vollständig importiert?

Dafür gibt es eine Lösung, und zwar schreibt ihr an den Anfang der Import-Datei die Zeile

– add this above the first line
SET FOREIGN_KEY_CHECKS = 0;

sowie als letzte Zeile

– add this below the last line
SET FOREIGN_KEY_CHECKS = 1;

Danach sollte der Import problemlos möglich sein, da ihr die Fremdschlüssel-Überprüfung während des Imports deaktiviert habt um die Tabellen in beliebiger Reihenfolge zu importieren. Außerdem wird der Import beschleunigt