How to Connect NodeMCU ESP8266 to MySQL Database
by Rishi Rishi in Circuits > Arduino
47416 Views, 16 Favorites, 0 Comments
How to Connect NodeMCU ESP8266 to MySQL Database
data:image/s3,"s3://crabby-images/bf8e8/bf8e83ab3cf35d28f1584ab28d524fe210311595" alt="How To Connect NodeMCU ESP8266 to MySQL/MariaDB Database (Remote Server Or Local PC)")
MySQL is a widely used relational database management system (RDBMS) that uses structured query language (SQL). At some point, you may want to upload Arduino/NodeMCU sensor data to the MySQL database. In this Instructable, we will see how to connect NodeMCU ESP8266 to the MySQL database.
Here I am going to use 000webhost to host MySQL database because of simplicity and free availability. However, you can use any platform with LAMP (Linux, Apache, MySQL/MariaDB, PHP) stack installed on it. Even you can use XAMPP to host MySQL database locally on your Windows PC.
In this instructable, I am not going to use any sensor. I will just increment two variables and insert them into the database. However, you can connect any sensor with your board.
Requirements:-
- NodeMCU ESP8266 development board
- Free version of 000webhost account (or MySQL installed on localhost)
- Filezilla FTP client (free version)
Create Web Application
- Navigate to 000webhost.com and login to your account.
- Locate Create New Site button on the top right corner of the window.
- Enter desired site name and password and then hit the create button. (Note down site password in a safe place because we are going to use it in upcoming steps).
- Proceed to Manage Website option.
Create MySQL Database
data:image/s3,"s3://crabby-images/fe820/fe82098edad3f0fbdbf2770bc88c3ba732124ab6" alt="db creation.JPG"
Navigate to Tools >> Database Manager and then create a new database.
After successfully creating the database, proceed to Manage >> PhpMyAdmin.
Create MySQL Database Table
data:image/s3,"s3://crabby-images/ee178/ee178caa94ed0bf03ba6f51c361140ab6a06f73e" alt="create table tricksumo.JPG"
data:image/s3,"s3://crabby-images/315ff/315ffbd2c0bd2b3f1dd4e9bbb66a123dc7b4c98d" alt="table.JPG"
- Locate and click on the database name in the left panel of PhpMyAdmin Window (as shown in screenshot a).
- Enter table name and number of columns (let it be 5). Then hit the Go button.
- Create columns (as per schema shown in screenshot b) and then hit save button.
Alternatively, you can create table by running the below command:-
CREATE TABLE `id13263538_sumodb`.`nodemcu_table` ( `id` INT(10) NOT NULL AUTO_INCREMENT , `val` FLOAT(10) NOT NULL , `val2` FLOAT(10) NOT NULL , `date` DATE NOT NULL , `time` TIME NOT NULL , PRIMARY KEY (`id`)) ENGINE = InnoDB;
Download and Edit PHP Files
data:image/s3,"s3://crabby-images/ba4b1/ba4b1289a5862931edd4515b2a979d88241421eb" alt="dbwrite.JPG"
data:image/s3,"s3://crabby-images/c90f9/c90f954665a40574171c4234536f34991ec0cc07" alt="dbread.JPG"
- Download dbwrite.php and dbread.php file from Github (or download attached files).
- Update database details and table name in dbwrite.php and dbread.php (as shown in screenshot).
Upload PHP Files to the Server
data:image/s3,"s3://crabby-images/e46fe/e46fedeb20380b6a212e034710f53ce83ca90b1c" alt="ftp.JPG"
data:image/s3,"s3://crabby-images/e2f01/e2f017dbb674bbaaa41910c7a5993dd83767b331" alt="filezilla.JPG"
- Navigate to Manage Website >> Website Settings >> General.
- Note down hostname, username, port and password (password is same as site password created in step1).
- Use these details to connect to the server using Filezilla FTP client (as shown in screenshot).
- Navigate to public_html folder and upload dbwrite.php and dbread.php files.
Edit and Upload Arduino (.ino) File to NodeMCU ESP8266
data:image/s3,"s3://crabby-images/cc4c9/cc4c9fb57d83dd46abaf6b98e7bd1b5a4670a085" alt="example.JPG"
data:image/s3,"s3://crabby-images/9e151/9e15185fe02f776a44235750f895d24d4c39cb05" alt="example tricksumo.JPG"
- Navigate to Manage Website >> Website Settings >> General and note down Website_Name (site URL).
- Edit .ino file to replace example.com with the name of your site. Also don't forget to update WiFi SSID and password.
- Finally, Upload code to NodeMCU.
Downloads
Check Connection to MySQL Database
data:image/s3,"s3://crabby-images/c1638/c16384076dbdd9e60f7e62ffbab13291b3fded3b" alt="mysql tricksumo nodemcu.JPG"
Once code is uploaded to NodeMCU, it will start sending data to MySQL database.
Visit "example.com/dbread.php" to view database values.
Hope you find this tutorial helpful. Enjoy!