Skip to main content

How to Use Two Database in Yii PHP Framework

Recently in one of Ireland based project client has requirement to use existing Microsoft SQL Server database and implement new feature and store data into MySQL database with Yii Framework.

First we have install and implement microsoft sql server driver in wamp server to make in localhost environment. Now we have to connect both the Database in Yii Framework. Following is steps to implement in Yii Framework :

1. In protected/config folder open main.php and add below code in component for mysql and sql server connection
'db'=>array(  // default mysql connection
 'connectionString' => 'mysql:host=localhost;port=3306;dbname=db_name',
 'emulatePrepare' => true,
 'username' => 'db_username',
 'password' => 'db_password',
 'charset' => 'utf8',
 'tablePrefix' =>'tbl_',  // if have prefix in database tables
),
'msdb'=>array( // microsoft sql server connection
 'class' => 'CDbConnection',
 'connectionString' => 'sqlsrv:Server=host_name or ip_address;Database=db_name',
 'username' => 'db_username',
 'password' => 'db_password',
 'charset' => 'GB2312',
),   

2. Now sql server connection is available in your entire application and access by CDbCommand
$company_name=Yii::app()->msdb->createCommand("SELECT TOP 1 CompanyName from Company_Details WHERE CompanyID="ezeelive")->queryRow();
if(isset($company_name) && !empty($company_name["CompanyName"])):
 echo $company_name["CompanyName"]; // it will print company name Ezeelive Technologies
else:
 echo '';
endif; 

In above example we have use msdb define database connection in component

3. Sometime we require to get the data from one table and insert into another database table, In this case you can use createCommand to write custom loop or you can Switch database connection runtime in model class
class Company extends CActiveRecord
{
 public function init()
 {
 $this->attachEventHandler('OnBeforeSave',   array($this,'switchToWriter'));
 $this->attachEventHandler('OnAfterSave',   array($this,'switchToReader'));
 }
 public function switchToWriter()
 {
 self::$db=Yii::app()->db;
 return true;
 }
 public function switchToReader()
 {
 self::$db=Yii::app()->msdb;
 return true;
 }
 //...
}    

In above example database connection will swapping means the connection will automatically change in fetching and inserting time. "switchToReader" function for fetching the data from SQL Server database and "switchToWriter" for insert/save data into MySQL database.

Please fill free to contact us on info@ezeelive.com or leave a comment for any type of development, integration and coding problem. Keep Coding...!!

Comments

Popular posts from this blog

The rise of generative AI startups in India and their impact on businesses

Generative AI startups are reshaping India’s business landscape , driving automation, personalization, and efficiency across industries. With advancements in deep learning, NLP, and computer vision, Indian startups are leveraging Generative AI to create innovative solutions in content creation, healthcare, fintech, e-commerce, and more . 1. The Boom of Generative AI Startups in India Several AI-driven startups in India are developing cutting-edge generative AI models , backed by increasing investments and government support. The rise of Digital India, AI-for-All, and startup incubators has accelerated AI innovation. 2. Key Generative AI Startups in India Ezeelive Technologies Expertise : AI-powered chatbot development and generative AI automation. Impact : Enhances customer engagement, automation, and AI-driven interactions for businesses. Writesonic Expertise : AI-driven content generation for blogs, ads, and copywriting. Impact : Automates content creation for businesses, reducin...

NLP-Based Chatbot Development: A Comprehensive Guide

  Natural Language Processing (NLP)-based chatbots are transforming customer interactions, automating support services, and enhancing business operations across various industries. These chatbots leverage AI and machine learning to understand, interpret, and respond to human language effectively. This article provides a detailed overview of NLP-based chatbot development, its benefits, key components, and the development process. What is an NLP-Based Chatbot? An NLP-based chatbot is a conversational agent powered by Natural Language Processing, a subset of AI that enables machines to understand, process, and generate human language. Unlike rule-based chatbots that follow predefined scripts, NLP chatbots analyze user input, recognize intent, and provide meaningful responses dynamically. Benefits of NLP-Based Chatbots Enhanced User Experience: NLP chatbots provide human-like conversations, making interactions more engaging and efficient. 24/7 Availability: Unlike human agents, these...

API Development with PHP: Everything You Need to Know

Application Programming Interfaces (APIs) are essential for modern web applications, enabling seamless communication between different services and platforms. PHP, being a powerful and flexible server-side scripting language, provides various tools and frameworks for building robust APIs. This article covers everything you need to know about API development with PHP, from fundamentals to best practices. Understanding APIs An API acts as an intermediary between different software applications, allowing them to communicate effectively. APIs can be categorized into different types, such as: REST (Representational State Transfer): Uses HTTP methods (GET, POST, PUT, DELETE) for communication. SOAP (Simple Object Access Protocol): A protocol that relies on XML messaging. GraphQL: A query language developed by Facebook for APIs that provides more flexibility. Setting Up a PHP API Development Environment Before developing an API with PHP, you need to set up a development environment. The fo...