Skip to main content

Get Google Calendar Event List in WordPress

<a href="https://console.cloud.google.com/apis/credentials">Get Your Api Credentials Here</a> <a href="https://calendar.google.com/calendar">Get your Calender ID</a> <?php include_once("wp-load.php"); function  get_calender_events() { $params = array(); /*Get current date*/ $current_date  = date('Y-m-d H:i:s'); /*Convert it to google calendar's rfc_format */ $rfc_format = date("c", strtotime($current_date)); $params[] = 'orderBy=startTime'; $params[] ='maxResults=100'; $params[] = 'timeMin='.urlencode($rfc_format); $url_param = ''; foreach($params as $param) { $url_param.= '&'.$param; } $calender_id = "calender_id"; $client_key =  "client_key"; $url = "https://www.googleapis.com/calendar/v3/calendars/".$calender_id."/events?key=".$client_key."&singleEvents=true".$url_param; $list_events = wp_remote_post($url, ...

Magento: How to select, insert, update, and delete data?

Magento: How to select, insert, update, and delete data?

Magento execute custom query to insert data
// fetch write database connection that is used in Mage_Core module
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
// now $write is an instance of Zend_Db_Adapter_Abstract
$write->query("INSERT INTO tablename VALUES ('111','aaa','abc123')");
Execute custom query to fetch data
$write = Mage::getSingleton('core/resource')->getConnection('core_write');

// now $write is an instance of Zend_Db_Adapter_Abstract
$result = $write->query("SELECT * FROM  `pepitashop_catalog_product_entity` LIMIT 0 , 30 ");


while ($row = $result->fetch() ) {
 $categoryIds[] = $row['id']; //insert into an array
}
Getting data into phtml files/view files
Method-1
// GETTING DATA FROM ANOTHER METHOD
$resource = Mage::getSingleton('core/resource');
$readConnection = $resource->getConnection('core_read');
$query = 'SELECT * FROM ' . $resource->getTableName('catalog/product');
$results = $readConnection->fetchAll($query);
Method-2
esource = Mage::getSingleton('core/resource');
$conn     = $resource->getConnection('core_read');
$results  = $conn->query("SELECT entity_id FROM catalog_product_entity_varchar WHERE entity_id = 65");  
$row = $results->fetchAll();

Execute custom query to update data
// Use in phtml files
$resource   = Mage::getSingleton('core/resource');
$conn       = $resource->getConnection('externaldb_read');
$conn->query("UPDATE sales_flat_order SET discount_qbt=12,comment_qbt ='test' WHERE increment_id=125");

******************************************

INSERT DATA
$data contains array of data to be inserted. The key of the array should be the database table’s field name and the value should be the value to be inserted.
$data = array('title'=>'hello there','content'=>'how are you? i am fine over here.','status'=>1);
$model = Mage::getModel('mynews/mynews')->setData($data);
try {
  $insertId = $model->save()->getId();
  echo "Data successfully inserted. Insert ID: ".$insertId;
 } catch (Exception $e){
  echo $e->getMessage();  
}

SELECT DATA
$item->getData() prints array of data from ‘news’ table.
$item->getTitle() prints the only the title field.
Similarly, to print content, we need to write $item->getContent().
$model = Mage::getModel('mynews/mynews');
$collection = $model->getCollection();
foreach($collection as $item){
 print_r($item->getData());
 print_r($item->getTitle());
}

UPDATE DATA
$id is the database table row id to be updated.
$data contains array of data to be updated. The key of the array should be the database table’s field name and the value should be the value to be updated.
// $id = $this->getRequest()->getParam('id');
$id = 2;
$data = array('title'=>'hello test','content'=>'test how are you?','status'=>0);
$model = Mage::getModel('mynews/mynews')->load($id)->addData($data);
try {
  $model->setId($id)->save();
  echo "Data updated successfully.";
   
 } catch (Exception $e){
  echo $e->getMessage();
}

DELETE DATA
$id is the database table row id to be deleted.
// $id = $this->getRequest()->getParam('id');
$id = 3;
$model = Mage::getModel('mynews/mynews');
try {
  $model->setId($id)->delete();
  echo "Data deleted successfully.";
   
 } catch (Exception $e){
  echo $e->getMessage();
}

*****************************

Database Connections In Magento
By default, Magento will automatically connect to it’s database and provide two separate resources which you can use to access data: core_read and core_write. As you can probably guess, core_read is for reading from the database while core_write is for writing to the database. It is important to ensure that you use the correct resource when reading or writing data to the database, especially when writing custom Magento extensions that will be released into the wild.
/**
     * Get the resource model
     */
    $resource = Mage::getSingleton('core/resource');
      
    /**
     * Retrieve the read connection
     */
    $readConnection = $resource->getConnection('core_read');
      
    /**
     * Retrieve the write connection
     */
    $writeConnection = $resource->getConnection('core_write');
Table names and table prefixes
When installing Magento, you are given the option to use a table prefix. A table prefix is a string of characters that is added to the start of every table name in your database. These are useful if you are installing multiple system into 1 database as it helps to distinguish each application’s data from another. Fortunately, Magento has a simple built in function which allows you to add the prefix to a given table name.
Get a table name from a string
/**
   * Get the resource model
   */
  $resource = Mage::getSingleton('core/resource');
    
  /**
   * Get the table name
   */
  $tableName = $resource->getTableName('catalog_product_entity');
    
  /**
   * if prefix was 'mage_' then the below statement
   * would print out mage_catalog_product_entity
   */
  echo $tableName;
Get a table name from an entity name
/**
 * Get the resource model
 */
$resource = Mage::getSingleton('core/resource');
  
/**
 * Get the table name
 */
$tableName = $resource->getTableName('catalog/product');
  
/**
 * if prefix was 'mage_' then the below statement
 * would print out mage_catalog_product_entity
 */
echo $tableName;
Reading From The Database
While Magento models hide the complexity of the EAV system, they sometimes request far more data than is needed. If for example you have a product ID and want it’s SKU, it would be much quicker to run a single query to obtain this value than to load in a whole product model (the inverse of this operation is available via the product resource class).
Varien_Db_Select::fetchAll
This method takes a query as it’s parameter, executes it and then returns all of the results as an array. In the code example below, we use Varien_Db_Select::fetchAll to return all of the records in the catalog_product_entity table.
/**
    * Get the resource model
    */
   $resource = Mage::getSingleton('core/resource');
     
   /**
    * Retrieve the read connection
    */
   $readConnection = $resource->getConnection('core_read');
     
   $query = 'SELECT * FROM ' . $resource->getTableName('catalog/product');
     
   /**
    * Execute the query and store the results in $results
    */
   $results = $readConnection->fetchAll($query);
     
   /**
    * Print out the results
    */
    var_dump($results);
Varien_Db_Select::fetchCol
This method is similar to fetchAll except that instead of returning all of the results, it returns the first column from each result row. In the code example below, we use Varien_Db_Select::fetchCol to retrieve all of the SKU’s in our database in an array.
/**
     * Get the resource model
     */
   $resource = Mage::getSingleton('core/resource');
     
   /**
    * Retrieve the read connection
    */
   $readConnection = $resource->getConnection('core_read');
     
   /**
    * Retrieve our table name
    */
   $table = $resource->getTableName('catalog/product');
 
   /**
    * Execute the query and store the results in $results
    */
   $sku = $readConnection->fetchCol('SELECT sku FROM ' . $table . ');
     
   /**
    * Print out the results
    */
    var_dump($results);
Try this code and look at the results. Notice how all of the SKU’s are in a single array, rather than each row having it’s own array? If you don’t understand this, try changing fetchCol for fetchAll and compare the differences.
Varien_Db_Select::fetchOne
Unlike the previous two methods, Varien_Db_Select::fetchOne returns one value from the first row only. This value is returned on it’s own and is not wrapped in an array. In the code example below, we take a product ID of 44 and return it’s SKU.
/**
    * Get the resource model
    */
   $resource = Mage::getSingleton('core/resource');
     
   /**
    * Retrieve the read connection
    */
   $readConnection = $resource->getConnection('core_read');
 
   /**
    * Retrieve our table name
    */
   $table = $resource->getTableName('catalog/product');
     
   /**
    * Set the product ID
    */
   $productId = 44;
     
   $query = 'SELECT sku FROM ' . $table . ' WHERE entity_id = '
            . (int)$productId . ' LIMIT 1';
     
   /**
    * Execute the query and store the result in $sku
    */
   $sku = $readConnection->fetchOne($query);
     
   /**
    * Print the SKU to the screen
    */
   echo 'SKU: ' . $sku . '<br/>';
When trying out this example, ensure you change the product ID to an ID that exists in your database!
You may think that fetchOne works the same as fetchCol or fetchAll would if you only added 1 column to the SELECT query and added a ‘LIMIT 1′, however you would be wrong. The main difference with this function is that the value returned is the actual value, where as Varien_Db_Select::fetchCol and Varien_Db_Select::fetchAll would wrap the value in an array. To understand this a little, try swapping the method’s and comparing the results.
Writing To The Database
When saving a Magento model, there can be a lot of background data being saved that you weren’t even aware of. For example, saving a product model can take several seconds due to the amount of related data saves and indexing that needs to take place. This is okay if you need all the data saving, but if you only want to update the SKU of a product, this can be wasteful.
The example code below will show you how when given a product ID, you can alter the SKU. This is a trivial example but should illustrate how to execute write queries against your Magento database.
/**
    * Get the resource model
    */
   $resource = Mage::getSingleton('core/resource');
     
   /**
    * Retrieve the write connection
    */
   $writeConnection = $resource->getConnection('core_write');
 
   /**
    * Retrieve our table name
    */
   $table = $resource->getTableName('catalog/product');
     
   /**
    * Set the product ID
    */
   $productId = 44;
     
   /**
    * Set the new SKU
    * It is assumed that you are hard coding the new SKU in
    * If the input is not dynamic, consider using the
    * Varien_Db_Select object to insert data
    */
   $newSku = 'new-sku';
     
   $query = "UPDATE {$table} SET sku = '{$sku}' WHERE entity_id = "
            . (int)$productId;
     
   /**
    * Execute the query
    */
   $writeConnection->query($query);
 

Comments

Popular posts from this blog

Create Signature pad with save on database in php

Create Signature pad with save on database in php 1.create a folder images index.php ============   <!DOCTYPE >     <head>     <meta content="text/html; charset=utf-8" http-equiv="Content-Type" />     <title>Signature Pad</title>     <script type="text/javascript" src="jquery-1.8.0.min.js"></script>     <script type="text/javascript"> $(document).ready(function () {     /** Set Canvas Size **/     var canvasWidth = 400;     var canvasHeight = 100;     /** IE SUPPORT **/     var canvasDiv = document.getElementById('signaturePad');     canvas = document.createElement('canvas');     canvas.setAttribute('width', canvasWidth);     canvas.setAttribute('height', canvasHeight);     canvas.setAttribute('id', 'canvas');     canvasDiv.appendChild(canvas);    ...

Get Google Calendar Event List in WordPress

<a href="https://console.cloud.google.com/apis/credentials">Get Your Api Credentials Here</a> <a href="https://calendar.google.com/calendar">Get your Calender ID</a> <?php include_once("wp-load.php"); function  get_calender_events() { $params = array(); /*Get current date*/ $current_date  = date('Y-m-d H:i:s'); /*Convert it to google calendar's rfc_format */ $rfc_format = date("c", strtotime($current_date)); $params[] = 'orderBy=startTime'; $params[] ='maxResults=100'; $params[] = 'timeMin='.urlencode($rfc_format); $url_param = ''; foreach($params as $param) { $url_param.= '&'.$param; } $calender_id = "calender_id"; $client_key =  "client_key"; $url = "https://www.googleapis.com/calendar/v3/calendars/".$calender_id."/events?key=".$client_key."&singleEvents=true".$url_param; $list_events = wp_remote_post($url, ...

WooCommerce Mini cart With Ajax

WooCommerce Mini cart //MINI CART SECTION   <div class="productdiv rightcart">                                                         <?php if ( ! WC()->cart->is_empty() ) : ?>     <ul class="woocommerce-mini-cart cart_list product_list_widget <?php echo esc_attr( $args['list_class'] ); ?>">         <?php             do_action( 'woocommerce_before_mini_cart_contents' );             foreach ( WC()->cart->get_cart() as $cart_item_key => $cart_item ) {                 $_product     = apply_filters( 'woocommerce_cart_item_pro...