table xxx has no column named id (code 1)?表中插入数据找不到字段?

问题

android.database.sqlite.SQLiteException: table xxx has no column named id (code 1): , while compiling:
INSERT xxx(name,id,position,isEnable) VALUES (?,?,?,?)

创建表的语句

这里写图片描述 这里写图片描述

以上代码是出现问题的代码,报错的原因已经标识出来,就是缺少***空格***。
导致插入数据的时候,找不到对应的字段,关键就是创建表的语句有问题,为:

这里写图片描述

这就是导致问题的原因,所以,如果您使用这种拼接的方式,一定要注意,空格问题。
您可以先在可视化数据库工具中,生成创建表的语句,然后在适当的修改,替换关键字。
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Django中,如果你遇到了表 `shiwenwang_j_entry` 没有名为 `date_added` 的列的问题,你可以尝试以下解决方法: 1. 确保数据库迁移已经执行:运行以下命令来检查并执行数据库迁移: ``` python manage.py makemigrations python manage.py migrate ``` 这将应用所有尚未应用的数据库迁移,并确保表结构与模型定义保持一致。 2. 检查模型定义:在 Django 中,表的结构是通过模型类定义的。确保你的模型类中存在名为 `date_added` 的字段,并且该字段数据库中的列名一致。示例模型类定义如下: ```python from django.db import models class ShiwenwangJEntry(models.Model): date_added = models.DateTimeField() # 其他字段... class Meta: db_table = 'shiwenwang_j_entry' ``` 确保在模型类中定义了正确的字段。 3. 执行数据库同步:如果你已经确认模型定义正确,并且迁移也已经执行了,但仍然遇到问题,可以尝试重新创建数据库表。首先,备份重要数据,然后运行以下命令: ``` python manage.py migrate --fake <app_name> zero python manage.py migrate <app_name> ``` 其中 `<app_name>` 是包含 `ShiwenwangJEntry` 模型的应用程序的名称。 4. 如果上述方法仍然无法解决问题,你可以尝试手动更改数据库表结构。首先,备份数据库,然后使用数据库管理工具(如phpMyAdmin或Navicat)手动添加名为 `date_added` 的列到 `shiwenwang_j_entry` 表中,并确保列的类型与模型中定义的字段类型一致。 请确保在执行任何数据库操作之前备份重要数据,并谨慎操作以避免数据丢失或损坏。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值