Firebase Data Connect আপনাকে Google Cloud SQL এর মাধ্যমে পরিচালিত আপনার PostgreSQL দৃষ্টান্তগুলির জন্য সংযোগকারী তৈরি করতে দেয়৷ এই সংযোগকারীগুলি আপনার স্কিমা থেকে আপনার ডেটা ব্যবহার করার জন্য একটি প্রশ্ন এবং মিউটেশনের সংমিশ্রণ।
শুরু করুন গাইড PostgreSQL-এর জন্য একটি মুভি পর্যালোচনা অ্যাপ স্কিমা প্রবর্তন করেছে।
সেই নির্দেশিকাটি নিয়োজিত এবং অ্যাডহক উভয় প্রশাসনিক ক্রিয়াকলাপও চালু করেছে, যার মধ্যে প্রশ্ন রয়েছে।
- ডিপ্লোয়েবল কোয়েরিগুলি হল যেগুলি আপনি ক্লায়েন্ট অ্যাপ থেকে কল করার জন্য প্রয়োগ করেন, আপনার সংজ্ঞায়িত API এন্ডপয়েন্ট সহ। আপনি এগুলিকে সার্ভারে স্থাপন করা একটি সংযোগকারীতে বান্ডিল করুন৷ Data Connect টুলিং আপনার API-এর উপর ভিত্তি করে ক্লায়েন্ট SDK তৈরি করে। স্থাপন করা প্রশ্নগুলি IAM নীতি দ্বারা সুরক্ষিত নয়, তাই Data Connect
@authনির্দেশিকা ব্যবহার করে সেগুলিকে সুরক্ষিত করতে ভুলবেন না। - অ্যাডহক প্রশাসনিক প্রশ্নগুলি ডেটা পড়ার জন্য বিশেষ সুবিধাপ্রাপ্ত পরিবেশ থেকে চালানো হয়। আপনি আমাদের ডেটা কানেক্ট VS কোড এক্সটেনশন ব্যবহার করে Firebase কনসোলে বা স্থানীয় উন্নয়ন পরিবেশে এগুলি তৈরি এবং কার্যকর করতে পারেন।
এই নির্দেশিকাটি স্থাপনযোগ্য প্রশ্নগুলির উপর গভীরভাবে নজর দেয়।
Data Connect প্রশ্নের বৈশিষ্ট্য
Data Connect আপনাকে পোস্টগ্রেএসকিউএল ডাটাবেস দিয়ে আশা করা সমস্ত উপায়ে মৌলিক প্রশ্নগুলি সম্পাদন করতে দেয়।
কিন্তু GraphQL-এ Data Connect এর এক্সটেনশনের সাহায্যে, আপনি দ্রুত, আরও দক্ষ অ্যাপের জন্য উন্নত কোয়েরি প্রয়োগ করতে পারেন:
- রেকর্ডে পুনরাবৃত্ত ক্রিয়াকলাপগুলিকে সহজ করার জন্য অনেকগুলি অপারেশন দ্বারা ফিরে আসা কী স্কেলারগুলি ব্যবহার করুন৷
- ডেটা খুঁজতে, কোডের লাইন সংরক্ষণ এবং সার্ভারে রাউন্ড ট্রিপ করার জন্য মাল্টি-স্টেপ মিউটেশন অপারেশনের কোর্সে প্রশ্নগুলি সম্পাদন করুন।
প্রশ্ন তৈরি করতে জেনারেটেড ক্ষেত্র ব্যবহার করুন
আপনার Data Connect ক্রিয়াকলাপগুলি আপনার স্কিমার প্রকার এবং টাইপ সম্পর্কের উপর ভিত্তি করে স্বয়ংক্রিয়ভাবে তৈরি Data Connect ক্ষেত্রগুলির একটি সেটকে প্রসারিত করবে। আপনি যখনই আপনার স্কিমা সম্পাদনা করেন তখন এই ক্ষেত্রগুলি স্থানীয় টুলিং দ্বারা তৈরি হয়।
আপনি ক্রমবর্ধমান জটিল প্রশ্নগুলি বাস্তবায়নের জন্য তৈরি করা ক্ষেত্রগুলি ব্যবহার করতে পারেন, একক টেবিল থেকে একাধিক রেকর্ড পুনরুদ্ধার করা থেকে সংশ্লিষ্ট টেবিল থেকে একাধিক রেকর্ডে। ধরে নিন আপনার স্কিমাতে একটি Movie ধরন এবং একটি সংশ্লিষ্ট Actor ধরন রয়েছে৷ Data Connect movie , movies , actors_on_movies ক্ষেত্র এবং আরও অনেক কিছু তৈরি করে।
সঙ্গে প্রশ্ন
movie ক্ষেত্র
| একটি একক মুভির কী দ্বারা অনুসন্ধান করতে এই ক্ষেত্রটি ব্যবহার করুন৷ query GetMovie($myKey: Movie_Key!) { movie(key: $myKey) { title } } |
সঙ্গে প্রশ্ন
movies ক্ষেত্র
| একাধিক সিনেমার জন্য এই ক্ষেত্রটি ব্যবহার করুন, উদাহরণস্বরূপ, একটি প্রদত্ত বছরের সমস্ত সিনেমা। query GetMovies($myYear: Int!) { movies(where: { year: { eq: $myYear } }) { title } } |
সঙ্গে প্রশ্ন
actors_on_movies ক্ষেত্র
| একটি প্রদত্ত চলচ্চিত্রের সাথে যুক্ত সমস্ত অভিনেতাদের জিজ্ঞাসা করতে এই ক্ষেত্রটি ব্যবহার করুন৷ query GetActorsOnMovie($myKey: Movie_Key!) { actors_on_movies(where: { movie: { key: { eq: $myKey } } }) { actor { name } } } |
একটি প্রশ্নের অপরিহার্য উপাদান
ডেটা কানেক্ট কোয়েরি হল ডেটা কানেক্ট এক্সটেনশন সহ গ্রাফকিউএল কোয়েরি। একটি নিয়মিত গ্রাফকিউএল কোয়েরির মতোই, আপনি একটি অপারেশনের নাম এবং গ্রাফকিউএল ভেরিয়েবলের একটি তালিকা নির্ধারণ করতে পারেন।
ডেটা কানেক্ট @auth মতো কাস্টমাইজড নির্দেশাবলী সহ GraphQL প্রশ্নগুলিকে প্রসারিত করে।
তাই নিম্নলিখিত ক্যোয়ারী আছে:
- একটি
queryধরন সংজ্ঞা - একটি
ListMoviesByGenreঅপারেশন (কোয়েরি) নাম - একটি একক ক্যোয়ারী আর্গুমেন্ট, এখানে
Stringটাইপের একটি$genreভেরিয়েবল - একটি একক নির্দেশনা,
@auth। - একটি একক ক্ষেত্র,
movies।
query ListMoviesByGenre($genre: String!) @auth(level: PUBLIC) {
movies(where: { genre: { eq: $genre } }) {
id
title
}
}
প্রতিটি ক্যোয়ারী আর্গুমেন্টের জন্য একটি টাইপ ডিক্লেয়ারেশন, String মত একটি বিল্ট-ইন বা Movie মত একটি কাস্টম, স্কিমা-সংজ্ঞায়িত টাইপ প্রয়োজন।
এই নির্দেশিকা ক্রমবর্ধমান জটিল প্রশ্নের স্বাক্ষর দেখবে। আপনি শক্তিশালী, সংক্ষিপ্ত সম্পর্কের অভিব্যক্তি প্রবর্তন করে শেষ করবেন যা আপনি আপনার স্থাপনযোগ্য প্রশ্ন তৈরি করতে ব্যবহার করতে পারেন।
প্রশ্নে মূল স্কেলার
কিন্তু প্রথম, কী স্কেলার সম্পর্কে একটি নোট।
Data Connect প্রতিটি টেবিলের প্রাথমিক কীগুলিকে উপস্থাপন করার জন্য একটি বিশেষ কী স্কেলার সংজ্ঞায়িত করে, যা {TableType}_Key দ্বারা চিহ্নিত করা হয়। এটি প্রাথমিক কী মানগুলির একটি JSON অবজেক্ট।
আপনি বেশিরভাগ স্বয়ংক্রিয়-উত্পন্ন পঠিত ক্ষেত্রগুলির দ্বারা প্রত্যাবর্তিত প্রতিক্রিয়া হিসাবে কী স্কেলারগুলি পুনরুদ্ধার করেন, বা অবশ্যই প্রশ্নগুলি থেকে যেখানে আপনি স্কেলার কী তৈরি করার জন্য প্রয়োজনীয় সমস্ত ক্ষেত্র পুনরুদ্ধার করেছেন৷
একক স্বয়ংক্রিয় প্রশ্ন, যেমন আমাদের চলমান উদাহরণে movie , একটি মূল যুক্তি সমর্থন করে যা একটি কী স্কেলার গ্রহণ করে।
আপনি আক্ষরিক হিসাবে একটি কী স্কেলার পাস করতে পারেন। কিন্তু, আপনি ইনপুট হিসাবে কী স্কেলারগুলি পাস করার জন্য ভেরিয়েবলগুলিকে সংজ্ঞায়িত করতে পারেন।
প্রশ্ন
query GetMovie($myKey: Movie_Key!) { movie(key: $myKey) { title } }
প্রতিক্রিয়া
{ "data": { "movie": { "title": "Example Movie Title" } } }
এগুলি এইভাবে (বা অন্যান্য সিরিয়ালাইজেশন ফরম্যাট) অনুরোধ JSON-এ প্রদান করা যেতে পারে:
{
# …
"variables": {
"myKey": {"id": "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx"}
}
}
কাস্টম স্কেলার পার্সিংয়ের জন্য ধন্যবাদ, একটি Movie_Key অবজেক্ট সিনট্যাক্স ব্যবহার করেও তৈরি করা যেতে পারে, যাতে ভেরিয়েবল থাকতে পারে। এটি বেশিরভাগ উপযোগী হয় যখন আপনি কোনো কারণে পৃথক উপাদানগুলিকে বিভিন্ন ভেরিয়েবলে ভাঙতে চান।
মৌলিক প্রশ্ন লিখুন
আপনি আপনার ডাটাবেস থেকে পৃথক রেকর্ড পেতে প্রশ্ন লেখা শুরু করতে পারেন, বা ফলাফল সীমাবদ্ধ করার এবং অর্ডার করার বিকল্প সহ একটি টেবিল থেকে রেকর্ড তালিকাভুক্ত করতে পারেন।
পৃথক রেকর্ড পুনরুদ্ধার করুন
সহজতম ক্যোয়ারী আইডি দ্বারা একটি একক রেকর্ড পায়। আপনার ক্যোয়ারী স্বয়ংক্রিয়ভাবে তৈরি movie ক্ষেত্র ব্যবহার করবে।
প্রশ্ন
query GetMovieById($id: UUID!) @auth(level: PUBLIC) { movie(id: $id) { id title imageUrl genre } }
প্রতিক্রিয়া
{ "data": { "movie": { "id": "some-uuid", "title": "Example Movie Title", "imageUrl": "https://example.com/movie.jpg", "genre": "Action" } } }
একটি টেবিলে সমস্ত রেকর্ড পুনরুদ্ধার করুন
Movies সারণী থেকে চলচ্চিত্রের সম্পূর্ণ তালিকার জন্য ক্ষেত্রগুলির একটি উপসেট পুনরুদ্ধার করতে, আপনার ক্যোয়ারীটি স্বয়ংক্রিয়-উত্পন্ন movies ক্ষেত্র ব্যবহার করবে এবং আপনার বাস্তবায়ন নিম্নলিখিতগুলির মতো দেখতে হতে পারে৷
প্রশ্ন
query ListMovies @auth(level: PUBLIC) { movies { id title imageUrl genre } }
প্রতিক্রিয়া
{ "data": { "movies": [ { "id": "some-uuid", "title": "Example Movie Title", "imageUrl": "https://example.com/movie.jpg", "genre": "Action" }, { "id": "another-uuid", "title": "Another Movie Title", "imageUrl": "https://example.com/another-movie.jpg", "genre": "Comedy" } ] } }
orderBy , limit এবং offset অপারেটর ব্যবহার করুন
স্বাভাবিকভাবেই, একটি টেবিল থেকে সমস্ত রেকর্ড তালিকাভুক্ত করার সীমিত উপযোগিতা আছে।
আপনি অর্ডার করতে পারেন এবং ফলাফলের উপর পৃষ্ঠা সংখ্যা করতে পারেন। এই যুক্তি গৃহীত হয় কিন্তু ফলাফল ফিরে না.
এখানে, ক্যোয়ারী রেটিং দ্বারা শীর্ষ 10 সিনেমার শিরোনাম পায়।
প্রশ্ন
query MoviesTop10 { movies(orderBy: [{ rating: DESC }], limit: 10) { # graphql: list the fields from the results to return title } }
প্রতিক্রিয়া
{ "data": { "movies": [ { "title": "Top Movie 1" }, { "title": "Top Movie 2" }, { "title": "Top Movie 3" } // ... other 7 movies ] } }
একটি অফসেট থেকে সারি আনার জন্য আপনার কাছে একটি ব্যবহারের ক্ষেত্রে থাকতে পারে, যেমন 11-20 রেটিংয়ের মাধ্যমে সাজানো সিনেমা।
প্রশ্ন
query Movies11to20 { movies(orderBy: [{ rating: DESC }], limit: 10, offset: 10) { # graphql: list the fields from the results to return title } }
প্রতিক্রিয়া
{ "data": { "movies": [ { "title": "Movie 11" }, { "title": "Movie 12" }, { "title": "Movie 13" } // ... other 7 movies ] } }
ক্যোয়ারীতে উপনাম ব্যবহার করুন
Data Connect প্রশ্নে গ্রাফকিউএল অ্যালিয়াসিং সমর্থন করে। উপনাম সহ, আপনি একটি প্রশ্নের ফলাফলে ফিরে আসা ডেটার নাম পরিবর্তন করুন৷ একটি একক Data Connect ক্যোয়ারী একাধিক ফিল্টার বা অন্যান্য ক্যোয়ারী ক্রিয়াকলাপ প্রয়োগ করতে পারে একটি দক্ষ অনুরোধে সার্ভারে, কার্যকরভাবে একাধিক "সাব-কোয়েরি" এক সাথে জারি করে৷ প্রত্যাবর্তিত ডেটাসেটে নামের সংঘর্ষ এড়াতে, আপনি উপ-কোয়েরিগুলিকে আলাদা করতে উপনাম ব্যবহার করেন।
এখানে একটি ক্যোয়ারী যেখানে একটি এক্সপ্রেশন mostPopular এবং leastPopular উপনাম ব্যবহার করে।
প্রশ্ন
query ReviewPopularitySpread($genre: String) { mostPopular: review( first: { where: {genre: {eq: $genre}}, orderBy: {popularity: DESC} } ), leastPopular: review( last: { where: {genre: {eq: $genre}}, orderBy: {popularity: DESC} } ) }
প্রতিক্রিয়া
{ "data": { "mostPopular": [ { "popularity": 9 } ], "leastPopular": [ { "popularity": 1 } ] } }
ক্যোয়ারী ফিল্টার ব্যবহার করুন
Data Connect ক্যোয়ারী সমস্ত সাধারণ এসকিউএল ফিল্টার এবং অর্ডার অপারেশনে ম্যাপ করে।
where orderBy দিয়ে অপারেটর দিয়ে ফিল্টার করুন
টেবিল (এবং নেস্টেড অ্যাসোসিয়েশন) থেকে সমস্ত মিলে যাওয়া সারি ফেরত দেয়। ফিল্টারের সাথে কোনো রেকর্ড না মিললে একটি খালি অ্যারে ফেরত দেয়।
প্রশ্ন
query MovieByTopRating($genre: String) { mostPopular: movies( where: { genre: { eq: $genre } }, orderBy: { rating: DESC } ) { # graphql: list the fields from the results to return id title genre description } }
প্রতিক্রিয়া
{ "data": { "mostPopular": [ { "id": "some-uuid", "title": "Example Movie Title", "genre": "Action", "description": "A great movie" } ] } }
শূন্য মান পরীক্ষা করে ফিল্টার করুন
আপনি isNull অপারেটর ব্যবহার করে null মান পরীক্ষা করতে পারেন।
প্রশ্ন
query ListMoviesWithoutDescription { movies(where: { description: { isNull: true }}) { id title } }
প্রতিক্রিয়া
{ "data": { "movies": [ { "id": "some-uuid", "title": "Example Movie Title" }, { "id": "another-uuid", "title": "Another Movie Title" } ] } }
আরও অপারেটরের জন্য, ইনপুট অবজেক্টের প্রকার রেফারেন্স গাইড দেখুন।
মান তুলনা সহ ফিল্টার
আপনি আপনার প্রশ্নের মান তুলনা করতে lt (এর চেয়ে কম) এবং ge (এর চেয়ে বড় বা সমান) অপারেটর ব্যবহার করতে পারেন।
প্রশ্ন
query ListMoviesByRating($minRating: Int!, $maxRating: Int!) { movies(where: { rating: { ge: $minRating, lt: $maxRating }}) { id title } }
প্রতিক্রিয়া
{ "data": { "movies": [ { "id": "some-uuid", "title": "Example Movie Title" }, { "id": "another-uuid", "title": "Another Movie Title" } ] } }
অ্যারে ক্ষেত্রের জন্য অপারেটর includes এবং excludes ফিল্টার করুন
আপনি পরীক্ষা করতে পারেন যে একটি অ্যারে ক্ষেত্রে একটি নির্দিষ্ট আইটেম অন্তর্ভুক্ত রয়েছে।
নিম্নলিখিত উদাহরণে অপারেটর includes ।
Data Connect সমর্থন করে includesAll , excludes , excludesAll এবং আরও অনেক কিছু। রেফারেন্স ডকুমেন্টেশনের _ListFilter শিরোনামে পূর্ণসংখ্যা, স্ট্রিং, তারিখ এবং অন্যান্য ডেটা প্রকারের জন্য এই ধরনের সমস্ত অপারেটর পর্যালোচনা করুন।
প্রশ্ন
query ListMoviesByTag($tag: String!) { movies(where: { tags: { includes: $tag }}) { # graphql: list the fields from the results to return id title } }
প্রতিক্রিয়া
{ "data": { "movies": [ { "id": "some-uuid", "title": "Example Movie Title" } ] } }
স্ট্রিং অপারেশন এবং রেগুলার এক্সপ্রেশন সহ ফিল্টার করুন
আপনার প্রশ্নগুলি সাধারণ স্ট্রিং অনুসন্ধান এবং তুলনামূলক ক্রিয়াকলাপগুলি ব্যবহার করতে পারে, রেগুলার এক্সপ্রেশন সহ। দ্রষ্টব্য দক্ষতার জন্য আপনি এখানে বেশ কয়েকটি ক্রিয়াকলাপ বান্ডিল করছেন এবং উপনাম দিয়ে তাদের দ্ব্যর্থহীন করছেন৷
query MoviesTitleSearch($prefix: String, $suffix: String, $contained: String, $regex: String) {
prefixed: movies(where: {title: {startsWith: $prefix}}) {...}
suffixed: movies(where: {title: {endsWith: $suffix}}) {...}
contained: movies(where: {title: {contains: $contained}}) {...}
}
_or , _and , _not অপারেটর লজিক দিয়ে ফিল্টার করুন
আরও জটিল যুক্তির জন্য _or ব্যবহার করুন। Data Connect _and এবং _not অপারেটরকেও সমর্থন করে।
প্রশ্ন
query ListMoviesByGenreAndGenre($minRating: Int!, $genre: String) { movies( where: { _or: [{ rating: { ge: $minRating } }, { genre: { eq: $genre } }] } ) { # graphql: list the fields from the results to return title } }
প্রতিক্রিয়া
{ "data": { "movies": [ { "title": "Movie Title 1" }, { "title": "Movie Title 2" } ] } }
সম্পর্কগত প্রশ্ন লিখুন
Data Connect কোয়েরিগুলি টেবিলের মধ্যে সম্পর্কের উপর ভিত্তি করে ডেটা অ্যাক্সেস করতে পারে। আপনি নেস্টেড কোয়েরি করতে আপনার স্কিমাতে সংজ্ঞায়িত অবজেক্ট (ওয়ান-টু-ওয়ান) বা অ্যারে (এক-থেকে-অনেক) সম্পর্ক ব্যবহার করতে পারেন, অর্থাৎ, নেস্টেড বা সম্পর্কিত টাইপের ডেটা সহ এক প্রকারের জন্য ডেটা আনতে পারেন।
এই ধরনের প্রশ্নগুলি তৈরি করা পঠিত ক্ষেত্রগুলিতে ম্যাজিক Data Connect _on_ এবং _via সিনট্যাক্স ব্যবহার করে।
নমুনা স্কিমা পর্যালোচনা করতে মনে রাখবেন।
অনেক থেকে এক
এখন _on_ সিনট্যাক্স চিত্রিত করার জন্য একটি প্রশ্ন দেখুন।
প্রশ্ন
query MyReviews @auth(level: USER) { user(key: {id_expr: "auth.uid"}) { reviews: reviews_on_user { movie { name } rating } } }
প্রতিক্রিয়া
{ "data": { "user": { "reviews": [ { "movie": { "name": "Movie Title" }, "rating": 5 } ] } } }
এক থেকে এক
আপনি _on_ সিনট্যাক্স ব্যবহার করে ওয়ান-টু-ওয়ান কোয়েরি লিখতে পারেন।
প্রশ্ন
query GetMovieMetadata($id: UUID!) @auth(level: PUBLIC) { movie(id: $id) { movieMetadatas_on_movie { director } } }
প্রতিক্রিয়া
{ "data": { "movie": { "movieMetadatas_on_movie": { "director": "Some Director" } } } }
অনেক থেকে অনেক
অনেক-থেকে-অনেক প্রশ্ন _via_ বাক্য গঠন ব্যবহার করে। একটি বহু-থেকে-অনেক প্রশ্ন একটি নির্দিষ্ট চলচ্চিত্রের জন্য অভিনেতাদের পুনরুদ্ধার করতে পারে৷
প্রশ্ন
query MoviesActors($id: UUID!) @auth(level: USER) { movie(id: $id) { actors: actors_via_MovieActors { name } } }
প্রতিক্রিয়া
{ "data": { "movie": { "actors": [ { "name": "Actor Name" } ] } } }
কিন্তু আমরা একটি আরও জটিল ক্যোয়ারী লিখতে পারি, উপনাম ব্যবহার করে, role উপর ভিত্তি করে ফিল্টার করতে পারি অভিনেতা এবং mainActors এবং supportingActors ফলাফলে সংশ্লিষ্ট সিনেমা পুনরুদ্ধার করতে। যেহেতু এটি বহু-থেকে-অনেক, তাই _via_ সিনট্যাক্স ব্যবহার করা হয়।
প্রশ্ন
query GetMovieCast($movieId: UUID!, $actorId: UUID!) @auth(level: PUBLIC) { movie(id: $movieId) { mainActors: actors_via_MovieActor(where: { role: { eq: "main" } }) { name } supportingActors: actors_via_MovieActor( where: { role: { eq: "supporting" } } ) { name } } actor(id: $actorId) { mainRoles: movies_via_MovieActor(where: { role: { eq: "main" } }) { title } supportingRoles: movies_via_MovieActor( where: { role: { eq: "supporting" } } ) { title } } }
প্রতিক্রিয়া
{ "data": { "movie": { "mainActors": [ { "name": "Main Actor Name" } ], "supportingActors": [ { "name": "Supporting Actor Name" } ] }, "actor": { "mainRoles": [ { "title": "Main Role Movie Title" } ], "supportingRoles": [ { "title": "Supporting Role Movie Title" } ] } } }
একত্রিত প্রশ্ন
সমষ্টি কি এবং কেন তাদের ব্যবহার?
সামগ্রিক ক্ষেত্রগুলি আপনাকে ফলাফলের তালিকায় গণনা করতে দেয়। সামগ্রিক ক্ষেত্রগুলির সাথে, আপনি কিছু করতে পারেন যেমন:
- একটি পর্যালোচনার গড় স্কোর খুঁজুন
- একটি শপিং কার্টে আইটেম মোট খরচ খুঁজুন
- সর্বোচ্চ বা সর্বনিম্ন রেটযুক্ত পণ্য খুঁজুন
- আপনার দোকানে পণ্য সংখ্যা গণনা
সমষ্টি সার্ভারে সঞ্চালিত হয়, যা তাদের ক্লায়েন্ট সাইড গণনা করার উপর অনেক সুবিধা প্রদান করে:
- দ্রুত অ্যাপ পারফরম্যান্স (যেহেতু আপনি ক্লায়েন্ট সাইড গণনা এড়ান)
- হ্রাসকৃত ডেটা এগ্রেস খরচ (যেহেতু আপনি সমস্ত ইনপুটের পরিবর্তে শুধুমাত্র সমষ্টিগত ফলাফল পাঠান)
- উন্নত নিরাপত্তা (যেহেতু আপনি ক্লায়েন্টদের সম্পূর্ণ ডেটা সেটের পরিবর্তে সমষ্টিগত ডেটাতে অ্যাক্সেস দিতে পারেন)
সমষ্টির জন্য উদাহরণ স্কিমা
এই বিভাগে, আমরা একটি স্টোরফ্রন্ট উদাহরণ স্কিমাতে স্যুইচ করব, যা সমষ্টি কীভাবে ব্যবহার করতে হয় তা ব্যাখ্যা করার জন্য ভাল:
type Product @table {
name: String!
manufacturer: String!
quantityInStock: Int!
price: Float!
expirationDate: Date
}
সরল সমষ্টি
_সমস্ত ক্ষেত্রের জন্য গণনা করুন
সহজতম সমষ্টি ক্ষেত্র হল _count : এটি আপনার প্রশ্নের সাথে কতগুলি সারি মেলে তা ফেরত দেয়। আপনার প্রকারের প্রতিটি ক্ষেত্রের জন্য, Data Connect ক্ষেত্রের প্রকারের উপর নির্ভর করে সংশ্লিষ্ট সমষ্টি ক্ষেত্র তৈরি করে।
প্রশ্ন
query CountProducts {
products {
_count
}
}
প্রতিক্রিয়া one
one
উদাহরণস্বরূপ, যদি আপনার ডাটাবেসে 5টি পণ্য থাকে, তাহলে ফলাফলটি হবে:
{
"products": [
{
"_count": 5
}
]
}
সমস্ত ক্ষেত্রের একটি <field>_count ক্ষেত্র রয়েছে, যা সেই ক্ষেত্রে কতগুলি সারি অ-নাল মান আছে তা গণনা করে।
প্রশ্ন
query CountProductsWithExpirationDate {
products {
expirationDate_count
}
}
প্রতিক্রিয়া field_count
field_count
উদাহরণস্বরূপ, যদি আপনার কাছে মেয়াদ শেষ হওয়ার তারিখ সহ 3টি পণ্য থাকে, তাহলে ফলাফল হবে:
{
"products": [
{
"expirationDate_count": 3
}
]
}
সাংখ্যিক ক্ষেত্রের জন্য _min, _max, _sum, এবং _avg
সাংখ্যিক ক্ষেত্রের (int, float, int64) এছাড়াও <field>_min , <field>_max , <field>_sum , এবং <field>_avg রয়েছে।
প্রশ্ন
query NumericAggregates {
products {
quantityInStock_max
price_min
price_avg
quantityInStock_sum
}
}
প্রতিক্রিয়া _min _max _sum _avg
_min _max _sum _avg
উদাহরণস্বরূপ, যদি আপনার নিম্নলিখিত পণ্য থাকে:
- পণ্য A:
quantityInStock: 10,price: 2.99 - পণ্য বি:
quantityInStock: 5,price: 5.99 - পণ্য C:
quantityInStock: 20,price: 1.99
ফলাফল হবে:
{
"products": [
{
"quantityInStock_max": 20,
"price_min": 1.99,
"price_avg": 3.6566666666666666,
"quantityInStock_sum": 35
}
]
}
তারিখ এবং টাইমস্ট্যাম্পের জন্য _মিনিট এবং _সর্বোচ্চ
তারিখ এবং টাইমস্ট্যাম্প ক্ষেত্রে <field>_min এবং <field>_max আছে।
প্রশ্ন
query DateAndTimeAggregates {
products {
expirationDate_max
expirationDate_min
}
}
প্রতিক্রিয়া _min _maxdatetime
_min _maxdatetime
উদাহরণস্বরূপ, যদি আপনার নিম্নলিখিত মেয়াদ শেষ হওয়ার তারিখ থাকে:
- পণ্য A:
2024-01-01 - পণ্য বি:
2024-03-01 - পণ্য C:
2024-02-01
ফলাফল হবে:
{
"products": [
{
"expirationDate_max": "2024-03-01",
"expirationDate_min": "2024-01-01"
}
]
}
স্বতন্ত্র
distinct যুক্তি আপনাকে একটি ক্ষেত্রের জন্য সমস্ত অনন্য মান পেতে দেয় (বা ক্ষেত্রের সংমিশ্রণ)। যেমন:
প্রশ্ন
query ListDistinctManufacturers {
products(distinct: true) {
manufacturer
}
}
প্রতিক্রিয়া distinct
distinct
উদাহরণস্বরূপ, যদি আপনার নিম্নলিখিত নির্মাতারা থাকে:
- পণ্য A:
manufacturer: "Acme" - পণ্য বি:
manufacturer: "Beta" - পণ্য সি:
manufacturer: "Acme"
ফলাফল হবে:
{
"products": [
{ "manufacturer": "Acme" },
{ "manufacturer": "Beta" }
]
}
আপনি স্বতন্ত্র মানগুলিকে একত্রিত করার পরিবর্তে সমষ্টি ক্ষেত্রের distinct যুক্তি ব্যবহার করতে পারেন। যেমন:
প্রশ্ন
query CountDistinctManufacturers {
products {
manufacturer_count(distinct: true)
}
}
প্রতিক্রিয়া distinctonaggregate
distinctonaggregate
উদাহরণস্বরূপ, যদি আপনার নিম্নলিখিত নির্মাতারা থাকে:
- পণ্য A:
manufacturer: "Acme" - পণ্য বি:
manufacturer: "Beta" - পণ্য সি:
manufacturer: "Acme"
ফলাফল হবে:
{
"products": [
{
"manufacturer_count": 2
}
]
}
গোষ্ঠীবদ্ধ সমষ্টি
আপনি একটি টাইপের সমষ্টিগত এবং অ-সমষ্টিক্ষেত্রের মিশ্রণ নির্বাচন করে একটি গোষ্ঠীবদ্ধ সমষ্টি সম্পাদন করেন। এই গোষ্ঠীগুলি সমস্ত মিলে যাওয়া সারিগুলিকে একত্রিত করে যেগুলির অ-সমষ্টিক্ষেত্রগুলির জন্য একই মান রয়েছে এবং সেই গোষ্ঠীর জন্য সমষ্টিগত ক্ষেত্রগুলি গণনা করে৷ যেমন:
প্রশ্ন
query MostExpensiveProductByManufacturer {
products {
manufacturer
price_max
}
}
প্রতিক্রিয়া groupedaggregates
groupedaggregates
উদাহরণস্বরূপ, যদি আপনার নিম্নলিখিত পণ্য থাকে:
- পণ্য A:
manufacturer: "Acme",price: 2.99 - পণ্য বি:
manufacturer: "Beta",price: 5.99 - পণ্য C:
manufacturer: "Acme",price: 1.99
ফলাফল হবে:
{
"products": [
{ "manufacturer": "Acme", "price_max": 2.99 },
{ "manufacturer": "Beta", "price_max": 5.99 }
]
}
having এবং where দলবদ্ধ সমষ্টি সহ
এছাড়াও আপনি having এবং where যুক্তি ব্যবহার করতে পারেন শুধুমাত্র একটি প্রদত্ত মানদণ্ড পূরণ করে এমন গোষ্ঠীগুলিকে ফেরত দিতে।
-
havingআপনাকে তাদের সমষ্টি ক্ষেত্র দ্বারা গোষ্ঠীগুলিকে ফিল্টার করতে দেয়৷ whereআপনাকে অ-সমষ্টিক্ষেত্রের উপর ভিত্তি করে সারিগুলি ফিল্টার করতে দেয়।
প্রশ্ন
query FilteredMostExpensiveProductByManufacturer {
products(having: {price_max: {ge: 2.99}}) {
manufacturer
price_max
}
}
প্রতিক্রিয়া havingwhere
havingwhere
উদাহরণস্বরূপ, যদি আপনার নিম্নলিখিত পণ্য থাকে:
- পণ্য A:
manufacturer: "Acme",price: 2.99 - পণ্য বি:
manufacturer: "Beta",price: 5.99 - পণ্য C:
manufacturer: "Acme",price: 1.99
ফলাফল হবে:
{
"products": [
{ "manufacturer": "Acme", "price_max": 2.99 },
{ "manufacturer": "Beta", "price_max": 5.99 }
]
}
টেবিল জুড়ে সমষ্টি
আপনার ডেটা সম্পর্কে জটিল প্রশ্নের উত্তর দিতে এক-থেকে-অনেক সম্পর্কযুক্ত ক্ষেত্রগুলির সাথে সমষ্টিগত ক্ষেত্রগুলি ব্যবহার করা যেতে পারে। এখানে একটি পরিবর্তিত স্কিমা রয়েছে, আলাদা টেবিল সহ, Manufacturer , আমরা উদাহরণে ব্যবহার করতে পারি:
type Product @table {
name: String!
manufacturer: Manufacturer!
quantityInStock: Int!
price: Float!
expirationDate: Date
}
type Manufacturer @table {
name: String!
headquartersCountry: String!
}
এখন আমরা একটি প্রস্তুতকারকের কতগুলি পণ্য তৈরি করে তা খুঁজে বের করার মতো জিনিসগুলি করতে সামগ্রিক ক্ষেত্রগুলি ব্যবহার করতে পারি:
প্রশ্ন
query GetProductCount($id: UUID) {
manufacturers {
name
products_on_manufacturer {
_count
}
}
}
প্রতিক্রিয়া aggregatesacrosstables
aggregatesacrosstables
উদাহরণস্বরূপ, যদি আপনার নিম্নলিখিত নির্মাতারা থাকে:
- প্রস্তুতকারক A:
name: "Acme",products_on_manufacturer: 2 - নির্মাতা বি:
name: "Beta",products_on_manufacturer: 1
ফলাফল হবে:
{
"manufacturers": [
{ "name": "Acme", "products_on_manufacturer": { "_count": 2 } },
{ "name": "Beta", "products_on_manufacturer": { "_count": 1 } }
]
}
ক্যোয়ারী গণনা ক্ষেত্র
আপনি আপনার স্কিমাতে গণনা ক্ষেত্রগুলি জিজ্ঞাসা করতে পারেন।
অনুমান করুন আমাদের গণনা এইভাবে বাস্তবায়িত হয়েছে:
enum AspectRatio {
ACADEMY
WIDESCREEN
ANAMORPHIC
IMAX
"No information available on aspect ratio"
UNAVAILABLE
}
উদাহরণস্বরূপ, আপনি আপনার পছন্দের আকৃতির অনুপাতের ফর্ম্যাট করা সমস্ত চলচ্চিত্র তালিকা করতে পারেন।
query ListMoviesByAspectRatio($aspectRatio: AspectRatio!) @auth(level: PUBLIC) {
movies(where:
{originalAspectRatio: {eq: $aspectRatio}}
) {
id
title
imageUrl
releaseYear
genre
rating
tags
description
otherAspectRatios
}
}
ফিল্টার গণনা ক্ষেত্র
Enums-এ স্ট্যান্ডার্ড ফিল্টারিং অ্যাকশন উপলব্ধ রয়েছে: eq , ne , ge , gt , lt , le , in nin , সেইসাথে includes , excludes , includesAll এবং excludesAll তালিকার জন্য৷
order , বৃহত্তর এবং কম অপারেটর অর্থপূর্ণ সম্পাদনের জন্য enum মানগুলির ক্রম ব্যবহার করে। enum এর শুরুতে মানগুলি enum সংজ্ঞার শেষে মানগুলির চেয়ে ছোট।
উদাহরণ স্বরূপ, নিম্নোক্ত where ক্লজ ইনপুট আকৃতির অনুপাতের চেয়ে কম ratio সহ সমস্ত চলচ্চিত্র ফেরত দেবে।
- প্রথম উদাহরণে, যদি
$aspectRatioIMAX হয়, তাহলে ACADEMY, WIDESCREEN, এবং ANAMORPHIC-এরratioসাথে মিলে যাওয়া সিনেমাগুলি নির্বাচন করা হবে৷ - দ্বিতীয় উদাহরণে, শুধুমাত্র ACADEMY এবং WIDESCREEN উভয় ক্ষেত্রে উপলব্ধ চলচ্চিত্রগুলি ফেরত দেওয়া হবে৷
movies(where: {originalAspectRatio: {lt: $aspectRatio}})
movies(where: {otherAspectRatios: {includesAll: [ACADEMY, WIDESCREEN]}})
গণনা ক্ষেত্রগুলিতে সমষ্টিগত প্রশ্নগুলি সম্পাদন করুন৷
শুধুমাত্র _count enums-এর জন্য সমর্থিত।
নিম্নলিখিত ক্যোয়ারী প্রতিটি আকৃতির অনুপাতের মোট সিনেমার সংখ্যা গণনা করে।
query MovieCountByOriginalAspectRatio @auth(level: PUBLIC) {
movies {
_count
originalAspectRatio
}
}
ক্লায়েন্ট কোড থেকে কল গণনা প্রশ্ন
আইওএস , অ্যান্ড্রয়েড , ওয়েব এবং ফ্লটারের জন্য SDK নির্দেশিকাগুলিতে ক্লায়েন্টদের থেকে গণনার প্রশ্নগুলি কীভাবে ব্যবহার করবেন এবং গণনা পরিচালনার ক্ষেত্রে আপনার নমনীয়তা সর্বাধিক করার জন্য কীভাবে ক্লায়েন্ট কলগুলি ডিজাইন করবেন তা শিখুন।
উন্নত প্রশ্নগুলি লিখুন: বহু-পদক্ষেপ ক্রিয়াকলাপে ডেটা পড়ার জন্য query ক্ষেত্রগুলি ব্যবহার করুন৷
এমন অনেক পরিস্থিতিতে আছে যেখানে আপনি একটি মিউটেশন কার্যকর করার সময় আপনার ডাটাবেস পড়তে চাইতে পারেন এবং পারফর্ম করার আগে বিদ্যমান ডেটা যাচাই করতে চান, উদাহরণস্বরূপ, সন্নিবেশ বা আপডেট। এই বিকল্পগুলি রাউন্ড ট্রিপ অপারেশন এবং তাই খরচ বাঁচায়।
Data Connect এই কার্যকারিতা সমর্থন করে। বহু-পদক্ষেপ অপারেশন দেখুন।
পরবর্তী পদক্ষেপ
আপনি আগ্রহী হতে পারে:
- AI সহায়তার টুল ব্যবহার করে আপনার অ্যাপের জন্য কোয়েরি তৈরি করা হচ্ছে
- অনুমোদন গাইড প্রতি আপনার প্রশ্ন অনুমোদন
- ওয়েব , iOS , অ্যান্ড্রয়েড এবং ফ্লটারের জন্য আপনার ক্লায়েন্ট কোড থেকে কল করা প্রশ্ন।