• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

React Native - Połączenie z baza danych SQlite

Object Storage Arubacloud
0 głosów
695 wizyt
pytanie zadane 22 marca 2017 w JavaScript przez Loki Użytkownik (560 p.)
edycja 22 marca 2017 przez Loki

Witam. Czy ktoś może mi powiedzieć jak w react-native dokonać połączenia z bazą danych sqlite?

W ramach nauki zainstalowałem sobie tą bibliotekę https://github.com/andpor/react-native-sqlite-storage

i próbuję stworzyć bazę danych oraz dokonać jakichś operacji, ale niestety stoję w miejscu z tym samym błędem.

Mój kod wygląda w ten sposób:

constructor() {
    super();
    this.state = {
        countryName:'',
        progress:''
    };
    this.startDB();

}
startDB(){

        SQLite.openDatabase({name: 'test.db', createFromLocation : "~example.db", location: 'Library'}).then((DB) => {
            db = DB;
            this.setState({
                progress:this.state.progress+"Database OPEN"
            });
        }).catch(error => {
           console.log(error);
           this.setState({
                progress:error
            });

        });
}

createDB(){

    db.executeSql('CREATE TABLE IF NOT EXISTS countrys( '
        + 'country_id INTEGER PRIMARY KEY NOT NULL, '
        + 'name VARCHAR(30) )');
}
adValue(){
    db.executeSql('INSERT INTO countrys (name) VALUES ("Polska")');
}

showValue(){
    db.executeSql('SELECT name FROM countrys').then((results) => {
        let len = results.rows.length;
        for (let i = 0; i < len; i++) {
            let row = results.rows.item(i);
            this.setState({
                countryName:this.state.countryName+row.name,
            });
        }

    }).catch((error) => {
        console.log(error);
    });
};

render() {
    return (
        <View>
            <Button
                color={'royalblue'}
                onPress={this.createDB}
                title="Create DB"
            />
            <Button
                color={'orange'}
                onPress={this.adValue}
                title="Add"
            />
            <Button
                color={'brown'}
                onPress={this.showValue}
                title="Show"
            />

            <Text>{this.state.countryName}</Text>
            <Text>{this.state.progress}</Text>
        </View>
    )
}
 
AppRegistry.registerComponent('SqliteComponent', () => SqliteComponent);

 

Po uruchomieniu aplikacji i kliknięciu w kolejne przyciski otrzymuję w konsoli takie komunikaty:

03-22 13:55:55.248 3386 3545 I ReactNativeJS: OPEN database: test
.db
03-22 13:55:55.249 3386 3545 I ReactNativeJS: SQLite.open({"name"
:"test.db","createFromLocation":"~example.db","location":"Library",
"dblocation":"libs","assetFilename":"~example.db"})
03-22 13:55:56.531 3386 3545 I ReactNativeJS: SQLite.backgroundEx
ecuteSqlBatch({"dbargs":{"dbname":"test.db"},"executes":[{"qid":111
1,"sql":"SELECT 1","params":[]},{"qid":1111,"sql":"CREATE TABLE IF
NOT EXISTS countrys( country_id INTEGER PRIMARY KEY NOT NULL, name
VARCHAR(30) ); ","params":[]}]})
03-22 13:56:08.196 3386 3545 I ReactNativeJS: SQLite.backgroundEx
ecuteSqlBatch({"dbargs":{"dbname":"test.db"},"executes":[{"qid":111
1,"sql":"SELECT 1","params":[]},{"qid":1111,"sql":"INSERT INTO coun
trys (name) VALUES ("Polska")","params":[]}]})
03-22 13:56:11.047 3386 3545 I ReactNativeJS: SQLite.backgroundEx
ecuteSqlBatch({"dbargs":{"dbname":"test.db"},"executes":[{"qid":111
1,"sql":"SELECT 1","params":[]},{"qid":1111,"sql":"SELECT name FROM
countrys","params":[]}]})
03-22 13:56:11.051 3386 3545 I ReactNativeJS: { [TypeError: undef
ined is not an object (evaluating 'results.rows.length')]
03-22 13:56:11.051 3386 3545 I ReactNativeJS: line: 76888,
03-22 13:56:11.051 3386 3545 I ReactNativeJS: column: 21,
03-22 13:56:11.051 3386 3545 I ReactNativeJS: sourceURL: 'http:
//10.0.2.2:8081/index.android.bundle?platform=android&dev=true&hot=
true&minify=false' }
03-22 13:57:06.646 3386 3545 I ReactNativeJS: 'Setting debug to:'
, true
03-22 13:57:06.646 3386 3545 I ReactNativeJS: Promise based runti
me ready
03-22 13:57:06.646 3386 3545 I ReactNativeJS: [React Transform HM
R] Patching SqliteComponent

 

Niestety nigdy wcześniej nie pracowałem z bazą danych SQlite więc jest to dla mnie nowum.

Jeśli dobrze rozumiem polecenie openDatabase stworzy plik jeśli nie istnieje. Chyba że muszę go wcześniej jakoś sam stworzyć?

Czy ktoś może spojrzeć na kod i powiedzieć dlaczego to nie działa?

Dziękuję

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
1 odpowiedź 403 wizyt
pytanie zadane 27 października 2021 w SQL, bazy danych przez Bakkit Dyskutant (7,600 p.)
0 głosów
0 odpowiedzi 621 wizyt
0 głosów
0 odpowiedzi 115 wizyt
pytanie zadane 1 kwietnia 2023 w JavaScript przez DzikieHarce Użytkownik (690 p.)

92,556 zapytań

141,404 odpowiedzi

319,563 komentarzy

61,942 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...