일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- GitHub
- MS-SQL
- 자바스크립트
- page
- 오류
- db
- typescript
- 닷넷
- AnimationController
- .NET
- spring boot
- listview
- JavaScript
- 마우이
- Binding
- 리엑트
- React JS
- 함수
- MVVM
- 깃허브
- 파이어베이스
- 애니메이션
- Firebase
- HTML
- 바인딩
- Flutter
- Maui
- 플러터
- MSSQL
- Animation
Archives
- Today
- Total
개발노트
55. [Flutter] Flutter에서 Firestore 쿼리 사용법 본문
반응형
Firestore의 CRUD를 Repository에서 어떻게 이용하는지 알아봅니다.
Model
Movie
class Movie {
String movieCode;
String movieName;
int score;
Movie({
required this.movieCode,
required this.movieName,
required this.score,
});
//Json 데이터 -> Movie로 변환
Movie.fromJson({required Map<String, dynamic> json})
: movieCode = json["movieCode"],
movieName = json["movieName"],
score = json["score"];
//Movie -> Json 데이터로 변환
Map<String, dynamic> toJson() {
return {
"movieCode": movieCode,
"movieName": movieName,
"score": score,
};
}
}
Repository
instance 생성 (FirebaseFirestore 사용을 위함)
final FirebaseFirestore _firestore = FirebaseFirestore.instance;
데이터 추가 생성 (Create)
데이터 추가 생성 시, Document 이름을 자동으로 생성할 경우 (랜덤한 문자열로 생성됨)
//삽입(document명 자동 생성)
Future<void> insertMovie(Movie movie) async {
final movieToJson = movie.toJson();
await _firestore.collection("movies").add(movieToJson);
}
데이터 추가 생성 시, Document 이름을 지정하여 생성할 경우
//삽입(document명 지정 생성)
Future<void> insertMovieCustom(Movie movie) async {
final movieToJson = movie.toJson();
await _firestore.collection("movies").doc("firstMovie").set(movieToJson);
}
데이터 조회(Read)
특정 값을 갖는 Document 데이터 가져오기
//조회
Future<Map<String, dynamic>?> getMovie(String movieCode) async {
final movie = await _firestore.collection("movies").doc(movieCode).get();
return movie.data();
}
특정 Collection에 포함되어있는 모든 Document 가져오기
//전체 조회
Future<List<Movie>> getAllmovie() async {
final querySnapshot = await _firestore.collection("movie").get();
return querySnapshot.docs
.map((movie) => Movie.fromJson(json: movie.data()))
.toList();
}
실시간 조회하기
//조회(실시간 Real Time)
Future<Map<String, dynamic>?> getMovieStream(String movieCode) async {
final movie = _firestore.collection("movies").doc(movieCode).snapshots();
await for (DocumentSnapshot snapshot in movie) {
Map<String, dynamic>? data = snapshot.data() as Map<String, dynamic>?;
return data ?? {};
}
return null;
}
조건을 걸어 조회하기
//특정 조건 조회 및 정렬하기
Future<QuerySnapshot<Map<String, dynamic>>> getMoviePopular() async {
final movie = _firestore
.collection("movies")
.where("score", isGreaterThan: 10000000) //1000만이 넘을 것
.where("movieCode", isNull: false) //movieCode가 null이 아닌 것
.where("movieName", isNull: false) //movidName이 null이 아닌 것
.orderBy("movieCode",descending: true) //내림차순으로 정렬
.get();
return movie;
}
- Firestore 조건문 종류: https://cloud.google.com/firestore/docs/query-data/queries?hl=ko#dart_3
데이터 수정(Update)
기존 Document에서 Json 데이터 통으로 수정하기
//업데이트
Future<void> updateMovie(Movie movie) async {
final movieToJson = movie.toJson();
await _firestore.collection("movies").doc(movie.movieCode).update(movieToJson);
}
지정된 Document의 특정 Field 값만 수정하기
//해당 movieCode의 score 수정하기
Future<void> updateMovieScore(Movie movie, int score) async {
await _firestore
.collection("movies")
.doc(movie.movieCode)
.update({"score": score});
}
값의 유무에 따라 삽입 또는 수정하기
//삽입 또는 업데이트
Future<void> setMovie(Movie movie) async {
final movieToJson = movie.toJson();
await _firestore.collection("movies").doc(movie.movieCode).set(movieToJson);
}
데이터 삭제(Delete)
Document 삭제하기
//삭제
Future<void> deleteMovie(String movieCode) async {
await _firestore.collection("movies").doc(movieCode).delete();
}
}
Field 삭제하기
//특정 Field 삭제하기
Future<void> deleteMovieField(String movieCode) async {
await _firestore.doc(movieCode).update({"movieName": FieldValue.delete()});
}
트랜젝션(Transaction) 태우기
Transaction 으로 데이터 처리하기
//트렌젝션으로 데이터 처리하기
Future<void> tranUpdateMovie() async {
final firstMovie = _firestore.collection("movies").doc("firstMovie");
_firestore.runTransaction((transaction) async {
final snapshot = await transaction.get(firstMovie);
final score = snapshot.get("score") + 1;
transaction.update(firstMovie, {"score": score});
}).then((value) => print("성공적으로 업데이트 되었습니다."),
onError: (e) => print("에러발생"));
}
일괄 쓰기 작업 만들기(Batch)
batch 로 set(), update(), delete() 조합하여 한번에 처리하기
//batch로 set, update, delete 작업 조합 사용하기
Future<void> batchMovie() async {
final batch = _firestore.batch();
//movies 컬랙션의 favoritMovie 다큐먼트
final docMovie = _firestore.collection("movies").doc("favoriteMovie");
batch.set(docMovie, {"movieCode": "168863"}); // movieCode 필드에 "168863" set()함
batch.set(docMovie, {"movieName": "GET OUT"}); // movieName 필드에 "GET OUT" set()함
batch.update(docMovie, {"score": "2130000"}); // score 필드에 2130000으로 update()
batch.delete(docMovie); //삭제
//batch를 커밋하여 한번에 처리함
batch.commit();
}
- 참고 사이트: https://firebase.google.com/docs/firestore/manage-data/transactions?hl=ko
- firestore에 대해 잘 정리된 Funncy님의 블로그글: https://funncy.github.io/flutter/2021/03/06/firestore/
반응형
'앱 개발 > Flutter' 카테고리의 다른 글
57. [Flutter] Push 알림 기능 추가하기(Firebase Cloud Messaging) (1) | 2024.01.26 |
---|---|
56. [Flutter] Provider에 Parameter 값 넘겨주기(with FamilyAsyncNotifier) (0) | 2024.01.25 |
54. [Flutter] Firebase functions 에 ffmpeg 패키지로 영상 썸네일 저장하기 (1) | 2024.01.09 |
53. [Flutter] Firebase Function 기능 활용하기 (1) | 2024.01.08 |
52. [Flutter] Firebase Storage 이용하기 (파일 업로드) (1) | 2024.01.05 |
Comments