Project: /docs/database/_project.yaml Book: /docs/_book.yaml page_type: guide
- Install
firebase_core
and add the initialization code to your app if you haven't already. - Add your app to your Firebase project in the Firebase console.
{# TODO(markarndt): Decide whether to include common files instead. #}
Navigate to the Realtime Database section of the Firebase console. You'll be prompted to select an existing Firebase project. Follow the database creation workflow.
Select a starting mode for your security rules:
Test mode
Good for getting started with the mobile and web client libraries, but allows anyone to read and overwrite your data. After testing, make sure to review the Understand Firebase Realtime Database Rules section.
Note: If you create a database in Test mode and make no changes to the default world-readable and world-writeable security rules within a trial period, you will be alerted by email, then your database rules will deny all requests. Note the expiration date during the Firebase console setup flow.
To get started, select testmode.
Locked mode
Denies all reads and writes from mobile and web clients. Your authenticated application servers can still access your database.
Choose a region for the database. Depending on your choice of region, the database namespace will be of the form
<databaseName>.firebaseio.com
or<databaseName>.<region>.firebasedatabase.app
. For more information, see select locations for your project.Click Done.
When you enable Realtime Database, it also enables the API in the Cloud API Manager.
From the root of your Flutter project, run the following command to install the plugin:
flutter pub add firebase_database
Once complete, rebuild your Flutter application:
flutter run
The Realtime Database provides a declarative rules language that allows you to define how your data should be structured, how it should be indexed, and when your data can be read from and written to.
<<_usecase_security_preamble.md>>
To start using the Realtime Database package within your project, import it at the top of your project files:
import'package:firebase_database/firebase_database.dart';
To use the default Database instance, call the instance
getter on FirebaseDatabase
:
FirebaseDatabase database =FirebaseDatabase.instance;
If you'd like to use it with a secondary Firebase App, use the static instanceFor
method:
FirebaseApp secondaryApp =Firebase.app('SecondaryApp'); FirebaseDatabase database =FirebaseDatabase.instanceFor(app: secondaryApp);
If you'd like to use a different RTDB instance on the same project, you can pass in a databaseUrl
using the static instanceFor
method:
final firebaseApp =Firebase.app(); final rtdb =FirebaseDatabase.instanceFor(app: firebaseApp, databaseURL:'https://your-realtime-database-url.firebaseio.com/');
Learn how to structure data for Realtime Database.