जब अपने ऐप्लिकेशन के डेटा को सेव करने के लिए, रूम परसिस्टेंस लाइब्रेरी का इस्तेमाल किया जाता है, तब सेव किए गए डेटा के साथ डेटा ऐक्सेस ऑब्जेक्ट या डीएओ तय करते हैं. सभी डीएओ इसमें ऐसे तरीके शामिल हैं जो आपके ऐप्लिकेशन के डेटाबेस का एब्सट्रैक्ट ऐक्सेस देते हैं. कंपाइलेशन के दौरान समय के हिसाब से, रूम अपने-आप आपके तय किए गए डीएओ लागू करता है.
अपने ऐप्लिकेशन के डेटाबेस को ऐक्सेस करने के लिए, क्वेरी बिल्डर या डायरेक्ट के बजाय डीएओ का इस्तेमाल करके है, तो आप Google Trends को अलग-अलग समस्याओं को हल करना. सिद्धांत. डीएओ, डेटाबेस ऐक्सेस की नकल करना भी आसान बनाते हैं, अपने ऐप्लिकेशन की जांच करें.
एनाटॉमी ऑफ़ अ डीएओ
हर डीएओ को इंटरफ़ेस या ऐब्सट्रैक्ट क्लास के तौर पर बताया जा सकता है. बुनियादी सेटिंग
इस्तेमाल करते हैं, तो आम तौर पर इंटरफ़ेस का इस्तेमाल किया जाता है. दोनों ही मामलों में, आपको हमेशा
@Dao
का इस्तेमाल करके, अपने डीएओ के बारे में बताएं. डीएओ
इसमें प्रॉपर्टी नहीं हैं, लेकिन प्रॉपर्टी से इंटरैक्ट करने के लिए, एक या उससे ज़्यादा तरीके बताए गए हैं
के डेटा के साथ अपने ऐप्लिकेशन के डेटाबेस में सेव करें.
नीचे दिया गया कोड एक आसान डीएओ का उदाहरण है, जो
रूम के डेटाबेस में User
ऑब्जेक्ट शामिल करना, मिटाना, और चुनना:
@Dao
interface UserDao {
@Insert
fun insertAll(vararg users: User)
@Delete
fun delete(user: User)
@Query("SELECT * FROM user")
fun getAll(): List<User>
}
@Dao
public interface UserDao {
@Insert
void insertAll(User... users);
@Delete
void delete(User user);
@Query("SELECT * FROM user")
List<User> getAll();
}
डेटाबेस इंटरैक्शन को दो तरह के डीएओ तरीकों से तय किया जाता है:
- ऐसी सुविधा विधियां जिनकी मदद से आप अपने कॉलम में पंक्तियां सम्मिलित कर सकते हैं, अपडेट कर सकते हैं और हटा सकते हैं बिना कोई एसक्यूएल कोड लिखे डेटाबेस बनाएं.
- क्वेरी के ऐसे तरीके जिनसे आपको इंटरैक्ट करने के लिए खुद की एसक्यूएल क्वेरी लिखने में मदद मिलती है डेटाबेस.
नीचे दिए गए सेक्शन में, दोनों तरह के डीएओ तरीकों का इस्तेमाल करने का तरीका बताया गया है अपने ऐप्लिकेशन के लिए ज़रूरी डेटाबेस इंटरैक्शन तय करें.
आसान तरीके
रूम, आसान परफ़ॉर्म करने वाले तरीके परिभाषित करने के लिए सुविधा एनोटेशन देता है SQL स्टेटमेंट लिखने की ज़रूरत के बिना, इंसर्शन, अपडेट, और मिटाना.
अगर आपको ज़्यादा कॉम्प्लेक्स इंसर्शन, अपडेट या मिटाने की ज़रूरत है या डेटाबेस के डेटा के बारे में क्वेरी करने के लिए, क्वेरी के तरीके का इस्तेमाल करें.
शामिल करें
@Insert
एनोटेशन से आपको
उन विधियों को परिभाषित करेगा, जो
डेटाबेस. नीचे दिए गए कोड में, ऐसे मान्य @Insert
तरीकों के उदाहरण दिए गए हैं जो
डेटाबेस में एक या उससे ज़्यादा User
ऑब्जेक्ट डालें:
@Dao
interface UserDao {
@Insert(onConflict = OnConflictStrategy.REPLACE)
fun insertUsers(vararg users: User)
@Insert
fun insertBothUsers(user1: User, user2: User)
@Insert
fun insertUsersAndFriends(user: User, friends: List<User>)
}
@Dao
public interface UserDao {
@Insert(onConflict = OnConflictStrategy.REPLACE)
public void insertUsers(User... users);
@Insert
public void insertBothUsers(User user1, User user2);
@Insert
public void insertUsersAndFriends(User user, List<User> friends);
}
@Insert
तरीके के लिए हर पैरामीटर, रूम का इंस्टेंस होना चाहिए
डेटा इकाई की क्लास के साथ एनोटेट किया गया हो
@Entity
या डेटा इकाई की क्लास के इंस्टेंस का कलेक्शन. इनमें से हर एक इंस्टेंस
डेटाबेस के बारे में बताता है. जब @Insert
तरीके को कॉल किया जाता है, तो रूम में हर एक तरीके को शामिल किया जाता है
इकाई के इंस्टेंस को संबंधित डेटाबेस टेबल में पास कर दिया जाता है.
अगर @Insert
तरीके को कोई एक पैरामीटर मिलता है, तो यह long
रिटर्न कर सकता है
वैल्यू, जो शामिल किए गए आइटम के लिए नया rowId
है. अगर पैरामीटर
अरे या कलेक्शन दिखाएं, फिर कोई अरे या कलेक्शन दिखाएं
के बजाय, long
मान का इस्तेमाल किया जाएगा. हर मान, डाले गए किसी एक मान के लिए rowId
के तौर पर होगा
आइटम. rowId
की वैल्यू दिखाने के बारे में ज़्यादा जानने के लिए, रेफ़रंस देखें
@Insert
के लिए दस्तावेज़
एनोटेशन और rowid के लिए SQLite दस्तावेज़
टेबल.
अपडेट करें
@Update
एनोटेशन से आपको
उन तरीकों को परिभाषित करें जो डेटाबेस टेबल में खास पंक्तियों को अपडेट करते हैं. किसी ने भी पसंद नहीं किया
@Insert
तरीके, @Update
तरीके डेटा इकाई के इंस्टेंस को पैरामीटर के तौर पर स्वीकार करते हैं.
नीचे दिया गया कोड एक ऐसे @Update
तरीके का उदाहरण देता है जो
डेटाबेस में एक या उससे ज़्यादा User
ऑब्जेक्ट अपडेट करें:
@Dao
interface UserDao {
@Update
fun updateUsers(vararg users: User)
}
@Dao
public interface UserDao {
@Update
public void updateUsers(User... users);
}
रूम, प्राइमरी पास किया गया मैच करने के लिए पासकोड इकाई के इंस्टेंस को डेटाबेस की पंक्तियों में शामिल करें. अगर एक जैसी कोई पंक्ति न हो प्राइमरी बटन है, तो रूम में कोई बदलाव नहीं होता.
@Update
वाला तरीका, विकल्प के तौर पर संख्या दिखाने वाली int
वैल्यू दे सकता है
अपडेट हुई.
मिटाएं
@Delete
एनोटेशन से आपको
उन तरीकों को परिभाषित करें जो किसी डेटाबेस टेबल से खास पंक्तियों को मिटा देते हैं. किसी ने भी पसंद नहीं किया
@Insert
तरीके, @Delete
तरीके डेटा इकाई के इंस्टेंस को पैरामीटर के तौर पर स्वीकार करते हैं.
नीचे दिया गया कोड एक ऐसे @Delete
तरीके का उदाहरण देता है जो
डेटाबेस से एक या उससे ज़्यादा User
ऑब्जेक्ट मिटाएं:
@Dao
interface UserDao {
@Delete
fun deleteUsers(vararg users: User)
}
@Dao
public interface UserDao {
@Delete
public void deleteUsers(User... users);
}
रूम, प्राइमरी पास किया गया मैच करने के लिए पासकोड इकाई के इंस्टेंस को डेटाबेस की पंक्तियों में शामिल करें. अगर एक जैसी कोई पंक्ति न हो प्राइमरी बटन है, तो रूम में कोई बदलाव नहीं होता.
कोई @Delete
तरीका वैकल्पिक रूप से, एक int
मान दे सकता है. यह मान बताता है कि
पंक्तियां जिन्हें सफलतापूर्वक हटा दिया गया था.
क्वेरी के तरीके
@Query
एनोटेशन से आपको
SQL स्टेटमेंट लिखें और उन्हें डीएओ मैथड के तौर पर दिखाएं. क्वेरी के इन तरीकों का इस्तेमाल करें
आपके ऐप्लिकेशन के डेटाबेस से क्वेरी डेटा या तब, जब आपको ज़्यादा मुश्किल काम करने की ज़रूरत हो
सम्मिलित करना, अपडेट करना और हटाना.
रूम, कंपाइल के समय पर एसक्यूएल क्वेरी की पुष्टि करता है. इसका मतलब है कि अगर कोई समस्या आपकी क्वेरी में इस्तेमाल होने पर, रनटाइम के दौरान होने वाली गड़बड़ी के बजाय, कंपाइलेशन से जुड़ी गड़बड़ी होती है.
सिंपल क्वेरी
यह कोड ऐसे तरीके के बारे में बताता है जो नतीजे देने के लिए आसान SELECT
क्वेरी का इस्तेमाल करता है
डेटाबेस में सभी User
ऑब्जेक्ट:
@Query("SELECT * FROM user")
fun loadAllUsers(): Array<User>
@Query("SELECT * FROM user")
public User[] loadAllUsers();
नीचे दिए गए सेक्शन में, सामान्य इस्तेमाल के लिए इस उदाहरण में बदलाव करने का तरीका बताया गया है मामले.
टेबल के कॉलम का सबसेट दिखाना
ज़्यादातर मामलों में, आपको टेबल से कॉलम का सिर्फ़ सबसेट लौटाना होता है क्वेरी की जा रही है. उदाहरण के लिए, आपका यूज़र इंटरफ़ेस (यूआई) सिर्फ़ पहला और उपयोगकर्ता के बारे में हर जानकारी के बजाय उसका उपनाम डालें. सेव करने के लिए और अपनी क्वेरी के निष्पादन को आसान बनाने के लिए, केवल डालें, जिनकी आपको ज़रूरत है.
रूम की मदद से, आपकी किसी भी क्वेरी से सामान्य ऑब्जेक्ट दिखाया जा सकता है. ऐसा सिर्फ़ तब तक के लिए किया जा सकता है, तो नतीजे के कॉलम के सेट को, दिखाए गए ऑब्जेक्ट पर मैप किया जा सकता है. उदाहरण के लिए, आपके उपयोगकर्ता के नाम और उपनाम को होल्ड करने के लिए, नीचे दिया गया ऑब्जेक्ट तय कर सकता है:
data class NameTuple(
@ColumnInfo(name = "first_name") val firstName: String?,
@ColumnInfo(name = "last_name") val lastName: String?
)
public class NameTuple {
@ColumnInfo(name = "first_name")
public String firstName;
@ColumnInfo(name = "last_name")
@NonNull
public String lastName;
}
इसके बाद, क्वेरी के तरीके से वह ऑब्जेक्ट दिखाया जा सकता है:
@Query("SELECT first_name, last_name FROM user")
fun loadFullName(): List<NameTuple>
@Query("SELECT first_name, last_name FROM user")
public List<NameTuple> loadFullName();
रूम समझता है कि क्वेरी, first_name
और
last_name
कॉलम जनरेट किए जा सकते हैं और इन वैल्यू को कॉलम में मौजूद फ़ील्ड पर मैप किया जा सकता है
NameTuple
क्लास. अगर क्वेरी से ऐसा कॉलम दिखता है जो किसी फ़ील्ड पर मैप नहीं करता
दिखाए गए ऑब्जेक्ट में, रूम एक चेतावनी दिखाता है.
किसी क्वेरी में आसान पैरामीटर पास करें
ज़्यादातर डीएओ तरीकों को पैरामीटर स्वीकार करने की ज़रूरत होती है, ताकि वे फ़िल्टर करने का काम करती है. रूम में, बाइंड के तौर पर मेथड के पैरामीटर का इस्तेमाल किया जा सकता है पैरामीटर की संख्या.
उदाहरण के लिए, नीचे दिया गया कोड एक ऐसा तरीका तय करता है जिससे सभी उपयोगकर्ता तय उम्र से ज़्यादा होने पर:
@Query("SELECT * FROM user WHERE age > :minAge")
fun loadAllUsersOlderThan(minAge: Int): Array<User>
@Query("SELECT * FROM user WHERE age > :minAge")
public User[] loadAllUsersOlderThan(int minAge);
आपके पास एक से ज़्यादा पैरामीटर पास करने या एक ही पैरामीटर को रेफ़रंस के तौर पर इस्तेमाल करने का विकल्प है क्वेरी में बार, जैसा कि नीचे दिए गए कोड में दिखाया गया है:
@Query("SELECT * FROM user WHERE age BETWEEN :minAge AND :maxAge")
fun loadAllUsersBetweenAges(minAge: Int, maxAge: Int): Array<User>
@Query("SELECT * FROM user WHERE first_name LIKE :search " +
"OR last_name LIKE :search")
fun findUserWithName(search: String): List<User>
@Query("SELECT * FROM user WHERE age BETWEEN :minAge AND :maxAge")
public User[] loadAllUsersBetweenAges(int minAge, int maxAge);
@Query("SELECT * FROM user WHERE first_name LIKE :search " +
"OR last_name LIKE :search")
public List<User> findUserWithName(String search);
किसी क्वेरी में पैरामीटर का कलेक्शन पास करना
कुछ डीएओ तरीकों के लिए, आपको ऐसे पैरामीटर जिनके बारे में रनटाइम तक पता नहीं चलता. चैट रूम तब समझता है, जब कोई पैरामीटर यह कलेक्शन को दिखाता है और रनटाइम के दौरान इस आधार पर अपने-आप बड़ा करता है पैरामीटर की संख्या दी गई है.
उदाहरण के लिए, नीचे दिया गया कोड एक ऐसा तरीका तय करता है जो क्षेत्रों के किसी सबसेट से सभी उपयोगकर्ता:
@Query("SELECT * FROM user WHERE region IN (:regions)")
fun loadUsersFromRegions(regions: List<String>): List<User>
@Query("SELECT * FROM user WHERE region IN (:regions)")
public List<User> loadUsersFromRegions(List<String> regions);
कई टेबल पर क्वेरी करें
आपकी कुछ क्वेरी को
नतीजा. अपनी एसक्यूएल क्वेरी में JOIN
क्लॉज़ का इस्तेमाल, इससे ज़्यादा रेफ़रंस के लिए किया जा सकता है
एक टेबल होगी.
यह कोड एक ऐसे तरीके के बारे में बताता है जो नतीजे देने के लिए तीन टेबल को एक साथ जोड़ता है फ़िलहाल, किसी उपयोगकर्ता के लिए क़र्ज़ पर दी जाने वाली किताबें:
@Query(
"SELECT * FROM book " +
"INNER JOIN loan ON loan.book_id = book.id " +
"INNER JOIN user ON user.id = loan.user_id " +
"WHERE user.name LIKE :userName"
)
fun findBooksBorrowedByNameSync(userName: String): List<Book>
@Query("SELECT * FROM book " +
"INNER JOIN loan ON loan.book_id = book.id " +
"INNER JOIN user ON user.id = loan.user_id " +
"WHERE user.name LIKE :userName")
public List<Book> findBooksBorrowedByNameSync(String userName);
एक से ज़्यादा कॉलम से कॉलम का सबसेट देने के लिए, आसान ऑब्जेक्ट भी तय किए जा सकते हैं शामिल की गई टेबल, जैसा कि टेबल की वैल्यू का सबसेट दिखाना कॉलम सेक्शन में कॉपी किया जा सकता है. यह कोड किसी डीएओ को ऐसे तरीके से परिभाषित करता है जो उपयोगकर्ताओं के नाम और उनसे ली गई किताबों के नाम दिखाता है:
interface UserBookDao {
@Query(
"SELECT user.name AS userName, book.name AS bookName " +
"FROM user, book " +
"WHERE user.id = book.user_id"
)
fun loadUserAndBookNames(): LiveData<List<UserBook>>
// You can also define this class in a separate file.
data class UserBook(val userName: String?, val bookName: String?)
}
@Dao
public interface UserBookDao {
@Query("SELECT user.name AS userName, book.name AS bookName " +
"FROM user, book " +
"WHERE user.id = book.user_id")
public LiveData<List<UserBook>> loadUserAndBookNames();
// You can also define this class in a separate file, as long as you add the
// "public" access modifier.
static class UserBook {
public String userName;
public String bookName;
}
}
मल्टीमैप दिखाना
रूम 2.4 और उसके बाद के वर्शन में, आपके पास कई टेबल के कॉलम के लिए क्वेरी करने का विकल्प भी है क्वेरी के ऐसे तरीके लिखकर अतिरिक्त डेटा क्लास तय करते हैं जो नतीजे के तौर पर मल्टीमैप.
एक से ज़्यादा टेबल के लिए क्वेरी करें सेक्शन से दिए गए उदाहरण पर विचार करें.
मौजूदा कस्टम डेटा क्लास के इंस्टेंस की सूची दिखाने के बजाय
User
और Book
इंस्टेंस को जोड़ने पर, User
और
सीधे आपके क्वेरी तरीके से Book
:
@Query(
"SELECT * FROM user" +
"JOIN book ON user.id = book.user_id"
)
fun loadUserAndBookNames(): Map<User, List<Book>>
@Query(
"SELECT * FROM user" +
"JOIN book ON user.id = book.user_id"
)
public Map<User, List<Book>> loadUserAndBookNames();
जब क्वेरी का आपका तरीका मल्टीमैप दिखाता है, तो आपके पास ऐसी क्वेरी लिखने का विकल्प होता है जिनमें
GROUP BY
क्लॉज़, जो एसक्यूएल की सुविधाओं का फ़ायदा देते हैं
हिसाब लगाने और फ़िल्टर करने की ऐडवांस सुविधाएं देते हैं. उदाहरण के लिए, आप
उन उपयोगकर्ताओं को लौटाने के लिए loadUserAndBookNames()
तरीका जिनके पास तीन या उससे ज़्यादा किताबें हैं
चेक आउट किया गया:
@Query(
"SELECT * FROM user" +
"JOIN book ON user.id = book.user_id" +
"GROUP BY user.name WHERE COUNT(book.id) >= 3"
)
fun loadUserAndBookNames(): Map<User, List<Book>>
@Query(
"SELECT * FROM user" +
"JOIN book ON user.id = book.user_id" +
"GROUP BY user.name WHERE COUNT(book.id) >= 3"
)
public Map<User, List<Book>> loadUserAndBookNames();
अगर आपको सभी ऑब्जेक्ट को मैप करने की ज़रूरत नहीं है, तो इनके बीच में भी मैपिंग को वापस किया जा सकता है
किसी कॉलम में बदलाव करने के लिए,
keyColumn
और
valueColumn
एट्रिब्यूट
आपकी@MapInfo
क्वेरी का तरीका:
@MapInfo(keyColumn = "userName", valueColumn = "bookName")
@Query(
"SELECT user.name AS username, book.name AS bookname FROM user" +
"JOIN book ON user.id = book.user_id"
)
fun loadUserAndBookNames(): Map<String, List<String>>
@MapInfo(keyColumn = "userName", valueColumn = "bookName")
@Query(
"SELECT user.name AS username, book.name AS bookname FROM user" +
"JOIN book ON user.id = book.user_id"
)
public Map<String, List<String>> loadUserAndBookNames();
सामान लौटाने के खास तरीके
रूम, अन्य एपीआई के साथ इंटिग्रेशन के लिए, सामान लौटाने की कुछ खास सुविधाएं देता है लाइब्रेरी.
पेजिंग लाइब्रेरी की मदद से, पेजों में नंबर डालकर की गई क्वेरी
पेजिंग
लाइब्रेरी पर जाएं. रूम 2.3.0-alpha01 और
ज़्यादा, डीएओ वापस आ सकते हैं
इस्तेमाल करने के लिए PagingSource
ऑब्जेक्ट
पेजिंग 3 के साथ.
@Dao
interface UserDao {
@Query("SELECT * FROM users WHERE label LIKE :query")
fun pagingSource(query: String): PagingSource<Int, User>
}
@Dao
interface UserDao {
@Query("SELECT * FROM users WHERE label LIKE :query")
PagingSource<Integer, User> pagingSource(String query);
}
PagingSource
के लिए टाइप पैरामीटर चुनने के बारे में ज़्यादा जानने के लिए, देखें
कुंजी और मान चुनें
टाइप.
कर्सर को सीधे तौर पर ऐक्सेस करना
अगर आपके ऐप्लिकेशन के लॉजिक के लिए रिटर्न पंक्तियों का सीधा ऐक्सेस चाहिए, तो
Cursor
वापस करने के लिए, आपके डीएओ तरीके
ऑब्जेक्ट, जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है:
@Dao
interface UserDao {
@Query("SELECT * FROM user WHERE age > :minAge LIMIT 5")
fun loadRawUsersOlderThan(minAge: Int): Cursor
}
@Dao
public interface UserDao {
@Query("SELECT * FROM user WHERE age > :minAge LIMIT 5")
public Cursor loadRawUsersOlderThan(int minAge);
}
अन्य संसाधन
रूम के डीएओ इस्तेमाल करके डेटा ऐक्सेस करने के बारे में ज़्यादा जानने के लिए, यहां दी गई अतिरिक्त जानकारी देखें संसाधन: