React Nativeでアプリ開発を行っております。
ExpoのSQLiteを使用したいと思っています。
テーブルは作成してデータもインサートした段階です。
データ取得を関数で取得したくて、インサートしたデータをreturnしたいのですが
結果がundefinedになってしまいます。
関数の仕組みがざっくりしか理解できていないのもあり、どのようにreturnできるのかわかりません。
ご教授のほどよろしくお願いいたします。
js
1// Get_databace.jsx 2 3import * as SQLite from "expo-sqlite"; 4 5// DB接続 6const db = SQLite.openDatabase("db"); 7 8export default function GetDB(){ 9 10 db.transaction((tx) => { 11 tx.executeSql( 12 `select * from test_table ;`, 13 [], 14 // SQL文が成功の場合 15 (_, { rows }) => { 16 17 // テーブル内の全データ 18 const data = rows._array; 19 20 // データが空じゃない場合 21 if (data.length) { 22 return data; //ここのデータがreturnされてほしい 23 } 24 25 }, 26 // SQL文が失敗の場合 27 () => { 28 console.log("select faile"); 29 } 30 ) 31 }) 32}
js
1// App.jsx 2 3import GetDB from './Get_databace'; 4import React, { useState, useEffect } from 'react'; 5 6export default function App() { 7 8 const [DB,setDB] = useState(null); 9 10 useEffect(() => { 11 const databace = GetDB(); //Get_databace.jsxのGetDBのreturn 12 setDB(databace) 13 console.log(DB) // → undefined 14 }, []); 15 16}
あなたの回答
tips
プレビュー