当查询响应中包含与其他表相关的关系时,DataStore会将其作为Promise返回。为了获取相关对象的实际值,我们需要使用async/await或then/catch来处理异步代码。
以下是一个示例,演示如何使用async/await处理具有关系oneToOne属性的查询响应:
import { DataStore } from 'aws-amplify';
const fetchUserAndAccountData = async () => {
const userData = await DataStore.query(User);
const accountData = await DataStore.query(Account);
const userWithAccount = userData.map(user => {
const account = accountData.find(account => account.id === user.accountId);
return { ...user, account };
});
return userWithAccount;
};
在上面的示例中,我们首先查询User和Account表中的数据,并使用async/await操作符将结果存储在userData和accountData变量中。然后,我们迭代userData数组,并在accountData数组中查找具有与当前用户关联的accountId的帐户。最后,我们将帐户数据添加到用户对象中,并将用户与帐户数据一起返回。
如果你更喜欢使用then/catch,你可以像下面这样写:
DataStore.query(User)
.then(userData => {
return DataStore.query(Account).then(accountData => {
const userWithAccount = userData.map(user => {
const account = accountData.find(account => account.id === user.accountId);
return { ...user, account };
});
return userWithAccount;
});
})
.catch(error => console.log(error));
请注意,这将使用嵌套的Promise来处理所述关系oneToOne属性。