Skip to content

Commit

Permalink
[sqflite] json1 doc
Browse files Browse the repository at this point in the history
  • Loading branch information
alextekartik committed Nov 28, 2023
1 parent 907dd79 commit df88c0e
Showing 1 changed file with 73 additions and 24 deletions.
97 changes: 73 additions & 24 deletions sqflite/doc/troubleshooting.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,12 @@
If you ran into build/runtime issues, please try the following:

* Update flutter to the latest version (`flutter upgrade`)
* Update sqflite dependencies to the latest version in your `pubspec.yaml`
(`sqflite >= X.Y.Z`)
* Update sqflite dependencies to the latest version in your `pubspec.yaml`
(`sqflite >= X.Y.Z`)
* Update dependencies (`flutter packages upgrade`)
* try `flutter clean`
* Try deleting the flutter cache folder (which will
downloaded again automatically) from your flutter installation folder `$FLUTTER_TOP/bin/cache`
* Try deleting the flutter cache folder (which will
downloaded again automatically) from your flutter installation folder `$FLUTTER_TOP/bin/cache`

# Recommendations

Expand Down Expand Up @@ -49,15 +49,18 @@ This error is typically a build/setup error after adding the dependency.
- Try to clean your build folder `flutter clean`
- On iOS, you can try to force a `pod install` / `pod update`
- Follow the [using package flutter guide](https://flutter.dev/docs/development/packages-and-plugins/using-packages)
- Search for [other bugs in flutter](https://github.com/flutter/flutter/search?q=MissingPluginException&type=Issues)
like this, other people face the same issue with other plugins so it is likely not sqflite related
- Search for [other bugs in flutter](https://github.com/flutter/flutter/search?q=MissingPluginException&type=Issues)
like this, other people face the same issue with other plugins so it is likely not sqflite related

Advanced checks:
- If you are using sqflite in a FCM Messaging context, you might need to [register the plugin earlier](https://github.com/tekartik/sqflite/issues/446).
- if the project was generated a long time ago (2019), you might have to follow the [plugin migration guide](https://flutter.dev/docs/development/packages-and-plugins/plugin-api-migration)

- If you are using sqflite in a FCM Messaging context, you might need
to [register the plugin earlier](https://github.com/tekartik/sqflite/issues/446).
- if the project was generated a long time ago (2019), you might have to follow
the [plugin migration guide](https://flutter.dev/docs/development/packages-and-plugins/plugin-api-migration)
- Check the GeneratedPluginRegistrant file that flutter run should have generated in your project contains
a line registering the plugin.

Android:
```java
SqflitePlugin.registerWith(registry.registrarFor("com.tekartik.sqflite.SqflitePlugin"));
Expand All @@ -66,7 +69,7 @@ Advanced checks:
```objective-c
[SqflitePlugin registerWithRegistrar:[registry registrarForPlugin:@"SqflitePlugin"]];
```
- Check MainActivity.java (Android) contains a call to
- Check MainActivity.java (Android) contains a call to
GeneratedPluginRegistrant asking it to register itself. This call should be made from the app
launch method (onCreate).
```java
Expand All @@ -78,7 +81,7 @@ Advanced checks:
}
}
```
- Check AppDelegate.m (iOS) contains a call to
- Check AppDelegate.m (iOS) contains a call to
GeneratedPluginRegistrant asking it to register itself. This call should be made from the app
launch method (application:didFinishLaunchingWithOptions:).
```objective-c
Expand All @@ -87,32 +90,41 @@ Advanced checks:
return [super application:application didFinishLaunchingWithOptions:launchOptions];
}
```
- If it happens to Android release mode, make sure to [remove shrinkResources
true and minifyEnabled true lines in build.gradle](https://github.com/tekartik/sqflite/issues/452#issuecomment-655602329) to solve the problem.
- If it happens to Android release mode, make sure to [remove shrinkResources
true and minifyEnabled true lines in build.gradle](https://github.com/tekartik/sqflite/issues/452#issuecomment-655602329)
to solve the problem.
Before raising this issue, try adding another well established plugin (the simplest being
Before raising this issue, try adding another well established plugin (the simplest being
`path_provider` or `shared_preferences`) to see if you get the error here as well.
## Warning database has been locked for...
## Warning database has been locked for...
If you get this output in debug mode:
> Warning database has been locked for 0:00:10.000000. Make sure you always use the transaction object for database operations during a transaction
> Warning database has been locked for 0:00:10.000000. Make sure you always use the transaction object for database
> operations during a transaction
One common mistake is to use the db object in a transaction:
```dart
await db.transaction((txn) async {
// DEADLOCK HERE
await db.insert('my_table', {'name': 'my_name'});
await
db.transaction
(
(txn) async {
// DEADLOCK HERE
await db.insert('my_table', {'name': 'my_name'});
});
```

...instead of using the correct transaction object (below named `txn`):

```dart
await db.transaction((txn) async {
// Ok!
await txn.insert('my_table', {'name': 'my_name'});
await
db.transaction
(
(txn) async {
// Ok!
await txn.insert('my_table', {'name': 'my_name'});
});
```

Expand All @@ -121,7 +133,9 @@ await db.transaction((txn) async {
A quick way to view SQL commands printed out is to call before opening any database

```dart
await Sqflite.devSetDebugModeOn(true);
await
Sqflite.devSetDebugModeOn
(true);
```

This call is on purpose deprecated to force removing it once the SQL issues has been resolved.
Expand Down Expand Up @@ -230,7 +244,7 @@ post_install do |installer|
end
```

you need to have
you need to have
(11 is used here, but you might want to specify a higher platform):

```
Expand Down Expand Up @@ -266,6 +280,41 @@ target 'Runner' do
end
```

## Runtime exception

### Json1 extension

```
DatabaseException: DatabaseException(no such function: JSON_OBJECT)
```

I could not find the details of what each built-in version includes (for
example the version os SQLite for each Android OS version
here https://developer.android.com/reference/android/database/sqlite/package-summary)
but I doubt any of them include the json1 extension.

json1 extension requires at least of SQLite 3.38.0 (2021-02-09) (https://www.sqlite.org/json1.html)

`sqflite` uses the SQLite available on the platform. It does not ship/bundle any additional SQLite library. You can get the
version using `SELECT sqlite_version()`:

```dart
print((await db.rawQuery('SELECT sqlite_version()')).first.values.first);
```

which should give a version formatted like this:

```
3.22.0
```

Unfortunately the version of SQLite depends on the OS version.

You could get a more recent version using [`sqflite_common_ffi`](https://pub.dev/packages/sqflite_common_ffi).

You could then add [`sqlite3_flutter_libs`](https://pub.dev/packages/sqlite3_flutter_libs) for ios/android or include your own
sqlite shared library for desktop or mobile (one for each platform).

## Error in Flutter web

Look at package [sqflite_common_ffi_web](https://pub.dev/packages/sqflite_common_ffi_web) for experimental Web support.
Expand Down

0 comments on commit df88c0e

Please sign in to comment.