flutter android SQlite '代码 1 SQLITE_ERROR,没有名为的列'

发布于 2025-01-10 14:44:55 字数 7610 浏览 0 评论 0原文

目前正在使用 SQlite,练习如何从文本字段保存文本。我可以只使用 1 个文本字段来完成此操作,但是当将其设置为低至 1 个文本字段时,它会让我失败。

发生异常。 SqfliteDatabaseException (DatabaseException(表声明没有名为 number 的列(代码 1 SQLITE_ERROR): ,编译时:INSERT INTO Claims (id, name, number) VALUES (NULL, ?, ?)) sql 'INSERT INTO Claims (id, name,数字) VALUES (NULL, ?, ?)' args [tt, 605])

// ignore_for_file: prefer_const_constructors

import 'dart:io';

import 'package:flutter/material.dart';
import 'package:sqflite/sqflite.dart';
import 'package:path/path.dart';
import 'package:path_provider/path_provider.dart';

// https://www.youtube.com/watch?v=noi6aYsP7Go
// this is where im getting all these from

main() {
  WidgetsFlutterBinding.ensureInitialized();
  runApp(SqliteApp());
}

class SqliteApp extends StatefulWidget {
  const SqliteApp({Key? key}) : super(key: key);

  @override
  _SqliteAppState createState() => _SqliteAppState();
}

class _SqliteAppState extends State<SqliteApp> {
  int? selectedId;
  final textController = TextEditingController();
  final textController2 = TextEditingController();

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(title: Text('TEST TEST')),
        body: SingleChildScrollView(
          child: Padding(
            padding: const EdgeInsets.all(10.0),
            child: Center(
              child: Column(
                children: [
                  TextField(
                    controller: textController,
                  ),
                  TextField(
                    controller: textController2,
                    keyboardType: TextInputType.number,
                  ),
                  SizedBox(
                    height: 500,
                    child: FutureBuilder<List<Claim>>(
                      future: DatabaseHelper.instance.getClaim(),
                      builder: (BuildContext context,
                          AsyncSnapshot<List<Claim>> snapshot) {
                        if (!snapshot.hasData) {
                          return Center(
                            child: Text('Loading...'),
                          );
                        }
                        return snapshot.data!.isEmpty
                            ? Center(
                                child: Text('No Claims in List.'),
                              )
                            : ListView(
                                children: snapshot.data!.map((claim) {
                                  return Center(
                                    child: Card(
                                      color: selectedId == claim.id
                                          ? Colors.grey
                                          : Colors.white,
                                      child: ListTile(
                                        title: Text(claim.name),
                                        onTap: () {
                                          setState(() {
                                            if (selectedId == null) {
                                              textController.text = claim.name;
                                              textController2.text =
                                                  claim.number;
                                              selectedId = claim.id;
                                            } else {
                                              textController.text = '';
                                              textController2.text = '';
                                              selectedId = null;
                                            }
                                          });
                                        },
                                        onLongPress: () {
                                          setState(() {
                                            DatabaseHelper.instance
                                                .remove(claim.id!);
                                          });
                                        },
                                      ),
                                    ),
                                  );
                                }).toList(),
                              );
                      },
                    ),
                  ),
                ],
              ),
            ),
          ),
        ),
        floatingActionButton: FloatingActionButton(
          child: Icon(Icons.save),
          onPressed: () async {
            if (textController.text.isEmpty) {
              null;
            } else {
              selectedId != null
                  ? await DatabaseHelper.instance.update(
                      Claim(
                          id: selectedId,
                          name: textController.text,
                          number: textController2.text),
                    )
                  : await DatabaseHelper.instance.add(
                      Claim(
                          name: textController.text,
                          number: textController2.text),
                    );
              setState(() {
                textController.clear();
                textController2.clear();
              });
            }
          },
        ),
      ),
    );
  }
}

class Claim {
  final int? id;
  final String name;
  final String number;

  Claim({this.id, required this.name, required this.number});

  factory Claim.fromMap(Map<String, dynamic> json) =>
      new Claim(id: json['id'], name: json['name'], number: json['number']);

  Map<String, dynamic> toMap() {
    return {
      'id': id,
      'name': name,
      'number': number,
    };
  }
}

class DatabaseHelper {
  DatabaseHelper._privateConstructor();
  static final DatabaseHelper instance = DatabaseHelper._privateConstructor();

  static Database?
      _database; // if the variable doesnt exist,,,,,,,, this (under) will initalise the database, and use set variable
  Future<Database> get database async => _database ??= await _initDatabase();

  Future<Database> _initDatabase() async {
    Directory documentsDirectory = await getApplicationDocumentsDirectory();
    String path = join(documentsDirectory.path, 'claims.db');
    return await openDatabase(
      path,
      version: 2,
      onCreate: _onCreate,
    );
  }

  Future _onCreate(Database db, int version) async {
    await db.execute('''
      CREATE TABLE claims(
        id INTEGER PRIMARY KEY,
        name TEXT
        number TEXT
      )
    ''');
  }

  Future<List<Claim>> getClaim() async {
    Database db = await instance.database;
    var claims = await db.query('claims', orderBy: 'id');
    List<Claim> claimList =
        claims.isNotEmpty ? claims.map((c) => Claim.fromMap(c)).toList() : [];
    return claimList;
  }

  Future<int> add(Claim claim) async {
    Database db = await instance.database;
    return await db.insert('claims', claim.toMap());
  }

  Future<int> remove(int id) async {
    Database db = await instance.database;
    return await db.delete('claims', where: 'id = ?', whereArgs: [id]);
  }

  Future<int> update(Claim claim) async {
    Database db = await instance.database;
    return await db.update('claims', claim.toMap(),
        where: 'id = ?', whereArgs: [claim.id]);
  }
}

使用这段代码,我不断收到代码 1 SQLITE_ERROR,我尝试一遍又一遍地调整它,但可惜的是,找不到解决方案。对于 flutter 还是一个业余爱好者,所以我没有太多经验

Currently using SQlite, practicing how to save text from textfield. I can do it with only 1 textfield, but when make it even as low as 1 more textfield, it fails me.

Exception has occurred. SqfliteDatabaseException (DatabaseException(table claims has no column named number (code 1 SQLITE_ERROR): , while compiling: INSERT INTO claims (id, name, number) VALUES (NULL, ?, ?)) sql 'INSERT INTO claims (id, name, number) VALUES (NULL, ?, ?)' args [tt, 605])

// ignore_for_file: prefer_const_constructors

import 'dart:io';

import 'package:flutter/material.dart';
import 'package:sqflite/sqflite.dart';
import 'package:path/path.dart';
import 'package:path_provider/path_provider.dart';

// https://www.youtube.com/watch?v=noi6aYsP7Go
// this is where im getting all these from

main() {
  WidgetsFlutterBinding.ensureInitialized();
  runApp(SqliteApp());
}

class SqliteApp extends StatefulWidget {
  const SqliteApp({Key? key}) : super(key: key);

  @override
  _SqliteAppState createState() => _SqliteAppState();
}

class _SqliteAppState extends State<SqliteApp> {
  int? selectedId;
  final textController = TextEditingController();
  final textController2 = TextEditingController();

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(title: Text('TEST TEST')),
        body: SingleChildScrollView(
          child: Padding(
            padding: const EdgeInsets.all(10.0),
            child: Center(
              child: Column(
                children: [
                  TextField(
                    controller: textController,
                  ),
                  TextField(
                    controller: textController2,
                    keyboardType: TextInputType.number,
                  ),
                  SizedBox(
                    height: 500,
                    child: FutureBuilder<List<Claim>>(
                      future: DatabaseHelper.instance.getClaim(),
                      builder: (BuildContext context,
                          AsyncSnapshot<List<Claim>> snapshot) {
                        if (!snapshot.hasData) {
                          return Center(
                            child: Text('Loading...'),
                          );
                        }
                        return snapshot.data!.isEmpty
                            ? Center(
                                child: Text('No Claims in List.'),
                              )
                            : ListView(
                                children: snapshot.data!.map((claim) {
                                  return Center(
                                    child: Card(
                                      color: selectedId == claim.id
                                          ? Colors.grey
                                          : Colors.white,
                                      child: ListTile(
                                        title: Text(claim.name),
                                        onTap: () {
                                          setState(() {
                                            if (selectedId == null) {
                                              textController.text = claim.name;
                                              textController2.text =
                                                  claim.number;
                                              selectedId = claim.id;
                                            } else {
                                              textController.text = '';
                                              textController2.text = '';
                                              selectedId = null;
                                            }
                                          });
                                        },
                                        onLongPress: () {
                                          setState(() {
                                            DatabaseHelper.instance
                                                .remove(claim.id!);
                                          });
                                        },
                                      ),
                                    ),
                                  );
                                }).toList(),
                              );
                      },
                    ),
                  ),
                ],
              ),
            ),
          ),
        ),
        floatingActionButton: FloatingActionButton(
          child: Icon(Icons.save),
          onPressed: () async {
            if (textController.text.isEmpty) {
              null;
            } else {
              selectedId != null
                  ? await DatabaseHelper.instance.update(
                      Claim(
                          id: selectedId,
                          name: textController.text,
                          number: textController2.text),
                    )
                  : await DatabaseHelper.instance.add(
                      Claim(
                          name: textController.text,
                          number: textController2.text),
                    );
              setState(() {
                textController.clear();
                textController2.clear();
              });
            }
          },
        ),
      ),
    );
  }
}

class Claim {
  final int? id;
  final String name;
  final String number;

  Claim({this.id, required this.name, required this.number});

  factory Claim.fromMap(Map<String, dynamic> json) =>
      new Claim(id: json['id'], name: json['name'], number: json['number']);

  Map<String, dynamic> toMap() {
    return {
      'id': id,
      'name': name,
      'number': number,
    };
  }
}

class DatabaseHelper {
  DatabaseHelper._privateConstructor();
  static final DatabaseHelper instance = DatabaseHelper._privateConstructor();

  static Database?
      _database; // if the variable doesnt exist,,,,,,,, this (under) will initalise the database, and use set variable
  Future<Database> get database async => _database ??= await _initDatabase();

  Future<Database> _initDatabase() async {
    Directory documentsDirectory = await getApplicationDocumentsDirectory();
    String path = join(documentsDirectory.path, 'claims.db');
    return await openDatabase(
      path,
      version: 2,
      onCreate: _onCreate,
    );
  }

  Future _onCreate(Database db, int version) async {
    await db.execute('''
      CREATE TABLE claims(
        id INTEGER PRIMARY KEY,
        name TEXT
        number TEXT
      )
    ''');
  }

  Future<List<Claim>> getClaim() async {
    Database db = await instance.database;
    var claims = await db.query('claims', orderBy: 'id');
    List<Claim> claimList =
        claims.isNotEmpty ? claims.map((c) => Claim.fromMap(c)).toList() : [];
    return claimList;
  }

  Future<int> add(Claim claim) async {
    Database db = await instance.database;
    return await db.insert('claims', claim.toMap());
  }

  Future<int> remove(int id) async {
    Database db = await instance.database;
    return await db.delete('claims', where: 'id = ?', whereArgs: [id]);
  }

  Future<int> update(Claim claim) async {
    Database db = await instance.database;
    return await db.update('claims', claim.toMap(),
        where: 'id = ?', whereArgs: [claim.id]);
  }
}

With this code, I keep getting the code 1 SQLITE_ERROR, i tried tweaking it over and over again but alas, can't find the solution. Still quite an amateur in flutter so I don't have much experience

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

伏妖词 2025-01-17 14:44:55

我认为您在创建索赔表时错过了逗号

Future _onCreate(Database db, int version) async {
    await db.execute('''
      CREATE TABLE claims(
        id INTEGER PRIMARY KEY,
        name TEXT,
        number TEXT
      )
    ''');
  }

我想提出一种更好的可读性方法

db.execute(
  "CREATE TABLE claims("
    "id INTEGER PRIMARY KEY, "
    "name TEXT, "
    "number TEXT)"
);

I think you missed a comma when creating the Claim table

Future _onCreate(Database db, int version) async {
    await db.execute('''
      CREATE TABLE claims(
        id INTEGER PRIMARY KEY,
        name TEXT,
        number TEXT
      )
    ''');
  }

I would like to propose a better way for readability

db.execute(
  "CREATE TABLE claims("
    "id INTEGER PRIMARY KEY, "
    "name TEXT, "
    "number TEXT)"
);
只是一片海 2025-01-17 14:44:55

数据库表的名称不是列的TEXT后面的逗号(,),
名称文本,

更改版本:1从物理设备卸载应用重新安装

希望问题能够得到解决。

Future _onCreate(Database db, int version) async {
        await db.execute('''
          CREATE TABLE claims(
            id INTEGER PRIMARY KEY,
            name TEXT, //You didn't give a comma here
            number TEXT
          )
        ''');
      }

否则请遵循我的代码

import 'package:sqflite/sqflite.dart' as sqlite;

class SQLHelper {
  static Future<sqlite.Database> db() async {
    return sqlite.openDatabase("info.db", version: 1,
        onCreate: (sqlite.Database database, int version) {
      database.execute(
          "CREATE TABLE note (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, title TEXT, description TEXT)");
      database.execute(
          "CREATE TABLE userdata (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name TEXT, phone TEXT, email TEXT, password TEXT)");
    });
  }

  static Future<int> insertData(String title, String description) async {
    final db = await SQLHelper.db();
    var values = {"title": title, "description": description};
    return db.insert("note", values);
  }

  static Future<List<Map<String, dynamic>>> getAllData() async {
    final db = await SQLHelper.db();
    return db.query("note", orderBy: "id");
  }

  static Future<int> updateData(
      int id, String title, String description) async {
    final db = await SQLHelper.db();
    var values = {"title": title, "description": description};
    return db.update("note", values, where: "id = ?", whereArgs: [id]);
  }

  static Future<int> deleteData(int id) async {
    final db = await SQLHelper.db();
    return db.delete("note", where: "id = ?", whereArgs: [id]);
  }
}

The name of the database table is not comma (,) after the TEXT of the column,
name TEXT,

Change the version : 1, uninstall the app from your physical device and reinstall.

Hopefully the problem will be solved.

Future _onCreate(Database db, int version) async {
        await db.execute('''
          CREATE TABLE claims(
            id INTEGER PRIMARY KEY,
            name TEXT, //You didn't give a comma here
            number TEXT
          )
        ''');
      }

Otherwise follow my code

import 'package:sqflite/sqflite.dart' as sqlite;

class SQLHelper {
  static Future<sqlite.Database> db() async {
    return sqlite.openDatabase("info.db", version: 1,
        onCreate: (sqlite.Database database, int version) {
      database.execute(
          "CREATE TABLE note (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, title TEXT, description TEXT)");
      database.execute(
          "CREATE TABLE userdata (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name TEXT, phone TEXT, email TEXT, password TEXT)");
    });
  }

  static Future<int> insertData(String title, String description) async {
    final db = await SQLHelper.db();
    var values = {"title": title, "description": description};
    return db.insert("note", values);
  }

  static Future<List<Map<String, dynamic>>> getAllData() async {
    final db = await SQLHelper.db();
    return db.query("note", orderBy: "id");
  }

  static Future<int> updateData(
      int id, String title, String description) async {
    final db = await SQLHelper.db();
    var values = {"title": title, "description": description};
    return db.update("note", values, where: "id = ?", whereArgs: [id]);
  }

  static Future<int> deleteData(int id) async {
    final db = await SQLHelper.db();
    return db.delete("note", where: "id = ?", whereArgs: [id]);
  }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文