Ir al contenido principal

Flutter / SQL / Singleton / Threads

SQL

In pubspec.yaml add

Add dependencies
dependencies:
flutter:
sdk: flutter
sqflite: any
path_provider: any
intl: ^0.15.7

^ Means above or equal to that version



SINGLETON
class DbHelper{
static final DbHelper _dbHelper = DbHelper._internal();

DbHelper._internal();

factory DbHelper(){
return _dbHelper;
}
}


Threads
Can be used with Futures or Sync & Wait

Initialize a DB
import 'package:sqflite/sqflite.dart';
import 'dart:async';
import 'dart:io';
import 'package:path_provider/path_provider.dart';

static Database _db;

Future<Database> get db async {
if (_db == null) {
_db = await initializeDb();
}
return _db;
}

Future<Database> initializeDb() async {
Directory dir = await getApplicationDocumentsDirectory();
String path = dir.path + "todos.db";
var dbTodos = await openDatabase(path, version: 1, onCreate: _createDb);
return dbTodos;
}

void _createDb(Database db, int version) async {
await db.execute(
"CREATE TABLE $tblTodo( $colId INTEGER PRIMARY KEY, $colTitle TEXT, $colDdescription TEXT, $colPriority INTEGER, $colDate TEXT )");
}


Funtional Methods

Future<int> insertTodo(Todo todo) async {
Database db = await this.db;
var result = await db.insert(tblTodo, todo.toMap());
return result;
}

Future<List> geTodo() async {
Database db = await this.db;
var result =
await db.rawQuery("SELECT * FROM $tblTodo order by $colPriority ASC");
return result;
}

Future<int> getCount() async {
Database db = await this.db;
var result = Sqflite.firstIntValue(await db.rawQuery("select count(*) from $tblTodo"));
return result;
}

Future<int> updateTodo(Todo todo) async {
Database db = await this.db;
var result = await db.update(tblTodo, todo.toMap(), where: "$colId = ?", whereArgs: [todo.id]);
return result;
}

Future<int> deleteTodo(int id) async {
Database db = await this.db;
int result = await db.rawDelete("delete from $tblTodo where $colId = $id");
return result;
}


Use of Db
DbHelper helper = DbHelper();
List <Todo> todos = List<Todo>();
helper.initializeDb().then(
(result) => helper.geTodo().then((result) => todos=result));
DateTime today = DateTime.now();
Todo todo = Todo("Buy Melon", 3, today.toString(), "make sure they are good");
helper.insertTodo(todo);

OR

final dbFuture = helper.initializeDb();
dbFuture.then((result) {
final todosFuture = helper.geTodo();
todosFuture.then((result) {
List<Todo> todoList = List<Todo>();
count = result.length;
for (var i = 0; i < count; i++) {
todoList.add(Todo.fromObject(result[i]));
debugPrint(todoList[i].title);
}
});
});



Comentarios

Entradas populares de este blog

C# Using tabs

To use tabs in C# use the TabContainer element from AjaxControlToolkit Include AjaxControlToolkit  Include in the Web.config file, inside the tag <system.web> the following code  <pages>       <controls>         <add tagPrefix="ajaxCTK" namespace="AjaxControlToolkit" assembly="AjaxControlToolkit"/>       </controls>     </pages>   Include TabContainer element First  include TabContainer element that is the section where all the tabs will be displayed. <ajaxCTK:TabContainer ID="TabContainerUpdate" runat="server"                 Height="800"                 CssClass="ajax__tab_style"> </ajaxCTK:TabContainer> Second per each tab include the following code corresponding to each ...

Rails - Basic Steps III

pValidations Validations are a type of ActiveRecord Validations are defined in our models Implement Validations Go to   root_app/app/models Open files  *.rb for each model Mandatory field validates_presence_of   :field Ex:   validates_presence_of    :title Classes The basic syntax is class MyClass        @global_variable                def my_method              @method_variable        end end Create an instance myInstance = MyClass.new Invoke a mehod mc.my_method class() method returns the type of the object In Ruby, last character of method define the behavior If ends with a question -> return a boolean value If ends with an exclamation -> change the state of the object Getter / Setter method def global_variable       return @global_variable end ...

Python create package

Create a root folder Create a sub-folder "example_pkg" that contains the funtionallity packaging_tutorial/ example_pkg/ __init__.py In the root folder create the following structure  packaging_tutorial/ example_pkg/ __init__.py tests/ setup.py LICENSE README.md in the setup.py contains the configuration of the packages your package is found by find_packages() import setuptools with open ( "README.md" , "r" ) as fh : long_description = fh . read () setuptools . setup ( name = "example-pkg-YOUR-USERNAME-HERE" , # Replace with your own username version = "0.0.1" , author = "Example Author" , author_email = "author@example.com" , description = "A small example package" , long_description = long_description , long_description_content_type = "text/markdown" , url = "https://github.com/pypa/sam...