Open In App

Firebase Realtime Database

Last Updated : 23 Jul, 2025
Comments
Improve
Suggest changes
1 Likes
Like
Report

Firebase Realtime Database is a powerful NoSQL cloud database that enables real-time data storage and synchronization across all clients. It's particularly suited for applications requiring live updates, such as chat apps and collaborative tools.

By following the setup instructions and using the provided examples we can take the help of Firebase Realtime Database to build efficient and interactive web applications that meet the demands of modern real-time data needs.

Here, We will learn about Firebase Realtime Database and how to set up Firebase Realtime Database in detail.

What is Firebase Realtime Database?

Firebase Realtime Database is a NoSQL cloud database that allows developers to store and sync data in real time across all clients. This makes it perfect for applications that require live updates, such as chat apps, collaborative tools, and real-time analytics. Firebase ensures low-latency performance by synchronizing data across all connected clients in milliseconds.

Key Features of Firebase Realtime Database:

  • Real-time Synchronization: Instantly updates data across all connected clients.
  • Offline Capabilities: Data is available locally even when the device is offline, and updates are synchronized when the device reconnects.
  • Scalability: Designed to handle large-scale applications.
  • Security: Provides robust authentication and database security rules to ensure data protection.

How to Set Up Firebase Realtime Database

Let us now see the steps required for setting up Firebase Realtime Database:

Step 1: Create a Firebase Project

Before using Firebase Realtime Database, you need to set up a Firebase project:

  • Create a Firebase Project: Go to the Firebase Console, click on "Add project," and follow the setup instructions.
  • Add Firebase to Your App: Firebase provides detailed guides for adding Firebase to various platforms (Web, iOS, Android). Follow the instructions specific to your platform to include Firebase in our project.

Step 2: Set Up Realtime Database

Enable Realtime Database:

  • Go to the Firebase Console.
  • Select your project.
  • Simply click on "Realtime Database" in the menu on the left-hand side.
  • Click on "Create Database."
  • Select your database location and security rules (Start in test mode for development purposes).

Step 3: Add Firebase SDK to Your Project

For a web application, include the Firebase SDK in your HTML file:

HTML
<!-- Firebase App (the core Firebase SDK) -->
<script src="https://www.gstatic.com/firebasejs/9.6.4/firebase-app.js"></script>

<!-- Firebase Realtime Database -->
<script src="https://www.gstatic.com/firebasejs/9.6.4/firebase-database.js"></script>

Step 4: Initialize Firebase

Initialize Firebase in your JavaScript file using the configuration details from your Firebase project settings:

JavaScript
// Your web app's Firebase configuration
const firebaseConfig = {
    apiKey: "AIzaSyDmaZAcK7xwQTAsQJxaGnG56oB8RIJDMnc",
    authDomain: "samplep-d6b68.firebaseapp.com",
    projectId: "samplep-d6b68",
    storageBucket: "samplep-d6b68.appspot.com",
    messagingSenderId: "398502093281",
    appId: "1:398502093281:web:5d685b0733d4d6d66472a0",
    measurementId: "G-9E6K9YD8D1"
};

// Initialize Firebase
firebase.initializeApp(firebaseConfig);

// Initialize Realtime Database and get a reference to the service
const database = firebase.database();

Explanation: The provided code snippet configures and initializes a Firebase app using specific project settings. The firebaseConfig object contains the necessary credentials and identifiers for connecting to your Firebase project, and the firebase.initializeApp(firebaseConfig) line initializes the Firebase app. The firebase.database() call sets up and references the Firebase Realtime Database service.

Working with Firebase Realtime Database

Step 1: Writing Data

To write data to Firebase Realtime Database, use the set method. This example demonstrates how to write user data to the database:

function writeUserData(userId, name, email) {
firebase.database().ref('users/' + userId).set({
username: name,
email: email
});
}
// Example usage
writeUserData('1', 'John Doe', '[email protected]');

Explanation: The writeUserData function writes user data to the Firebase Realtime Database. It takes three parameters: userId, name, and email. It creates or updates a user entry in the users node of the database with the provided userId, setting the username and email fields. The example usage demonstrates calling the function to store data for a user with ID 1, name John Doe, and email [email protected]

Step 2: Reading Data

To read data from Firebase Realtime Database, use the once method to read data once or the on method to listen for changes in the data.

  • Reading Data Once:
function readUserData(userId) {
const userRef = firebase.database().ref('users/' + userId);
userRef.once('value').then((snapshot) => {
const data = snapshot.val();
console.log(data);
});
}

// Example usage
readUserData('1');

Explanation: The readUserData function reads the data for the user with the specified userId from the users node in the Firebase Realtime Database. It uses the once method to retrieve the data once and logs the retrieved data to the console. The example usage retrieves and logs data for the user with ID 1.

  • Listening for Data Changes:
function listenForUserData(userId) {
const userRef = firebase.database().ref('users/' + userId);
userRef.on('value', (snapshot) => {
const data = snapshot.val();
console.log(data);
});
}

// Example usage
listenForUserData('1');

Explanation: The listenForUserData function sets up a real-time listener on the users node in the Firebase Realtime Database for the specified userId. It uses the on method to listen for any changes to the data. When the data changes, the new data is retrieved and logged to the console. The example usage sets up a listener for changes to the user data for the user with ID 1.

Step 3: Updating Data

To update specific fields in your data without overwriting the entire node, use the 'update' method:

function updateUserData(userId, email) {
const updates = {};
updates['/users/' + userId + '/email'] = email;

firebase.database().ref().update(updates);
}

// Example usage
updateUserData('1', '[email protected]');

Explanation: The updateUserData function creates an updates object with the path to the user's email (/users/{userId}/email) as the key and the new email address as the value. It then uses the update method of the Firebase Realtime Database to update the specified user's email address. The example usage updates the email address for the user with ID 1 to [email protected]

Step 4: Deleting Data

To delete data from Firebase Realtime Database, use the remove method:

function deleteUser(userId) {
firebase.database().ref('users/' + userId).remove()
.then(() => {
console.log('User removed successfully.');
})
.catch((error) => {
console.error('Error removing user:', error);
});
}

// Example usage
deleteUser('1');

Explanation: The deleteUser function removes the user with the specified userId from the users node in the Firebase Realtime Database. It uses the remove method to delete the user and handles the success and error cases using then and catch methods respectively. The example usage deletes the user with ID 1.

Firebase Realtime Database Example: Real-Time Chat Application

Let's build a simple real-time chat application to demonstrate Firebase Realtime Database in action.

HTML
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Real-Time Chat Application</title>
<style>
body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 0;
    background-color: #f4f4f4;
}

.chat-container {
    max-width: 600px;
    margin: 20px auto;
    padding: 20px;
    background-color: #fff;
    border-radius: 5px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

#chat-window {
    height: 300px;
    overflow-y: scroll;
    border: 1px solid #ccc;
    padding: 10px;
    margin-bottom: 10px;
}

#message-input {
    width: calc(100% - 70px);
    padding: 5px 10px;
    margin-right: 10px;
}

#send-button {
    padding: 5px 10px;
    background-color: #007bff;
    color: #fff;
    border: none;
    border-radius: 3px;
    cursor: pointer;
}

#send-button:hover {
    background-color: #0056b3;
}
</style>
</head>
<body>
<div class="chat-container">
    <div id="chat-window"></div>
    <input type="text" id="message-input" placeholder="Type your message...">
    <button id="send-button">Send</button>
</div>

<script src="https://www.gstatic.com/firebasejs/9.6.4/firebase-app.js"></script>
<script src="https://www.gstatic.com/firebasejs/9.6.4/firebase-database.js"></script>
<script>
const firebaseConfig = {
            apiKey: "AIzaSyDmaZAcK7xwQTAsQJxaGnG56oB8RIJDMnc",
            authDomain: "samplep-d6b68.firebaseapp.com",
            projectId: "samplep-d6b68",
            storageBucket: "samplep-d6b68.appspot.com",
            messagingSenderId: "398502093281",
            appId: "1:398502093281:web:5d685b0733d4d6d66472a0",
            measurementId: "G-9E6K9YD8D1"
        };

// Initialize Firebase
firebase.initializeApp(firebaseConfig);

const database = firebase.database();
const chatWindow = document.getElementById('chat-window');
const messageInput = document.getElementById('message-input');
const sendButton = document.getElementById('send-button');

sendButton.addEventListener('click', () => {
    const message = messageInput.value.trim();
    if (message !== '') {
        database.ref('messages').push({
            message: message,
            timestamp: firebase.database.ServerValue.TIMESTAMP
        });
        messageInput.value = '';
    }
});

database.ref('messages').on('child_added', (snapshot) => {
    const messageData = snapshot.val();
    const messageElement = document.createElement('div');
    messageElement.textContent = messageData.message;
    chatWindow.appendChild(messageElement);
    chatWindow.scrollTop = chatWindow.scrollHeight;
});
</script>
</body>
</html>

Output:

Firebase Realtime Database example output
Final Output

Conclusion

Overall, Firebase Realtime Database offers developers a robust solution for building real-time applications that require synchronized data across clients. By setting up a Firebase project, adding Firebase to your app, and initializing the Realtime Database, you can quickly get started with storing and syncing data in real-time. You can also set up and integrate Firebase Realtime Database into your project, perform essential CRUD operations, and build interactive applications like real-time chat. The provided examples demonstrate how to write, read, update, and delete data, as well as how to build a real-time chat application.


Article Tags :

Explore