4

5 つの列と大量のデータを含む特定のテーブルを持つ既存のデータベースがありました。(これをCSVからインポートしました)

MySql で DESCRIBE student_info を実行すると、次のように表示されます。

+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| pic_id | int(11)     | YES  |     | NULL    |       |
| name   | varchar(50) | YES  |     | NULL    |       |
| hostel | varchar(3)  | YES  |     | NULL    |       |
| room   | int(11)     | YES  |     | NULL    |       |
| branch | varchar(4)  | YES  |     | NULL    |       |
| id_no  | varchar(12) | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+

このテーブルには、さまざまな SELECT ステートメントと Workbench を介してテストしたすべてのデータが含まれています。

settings.py で、プロジェクトがそのデータベースに正常に接続するように構成しました。それから、私は命令を出しました

python manage.py inspectdb > studentinfo/models.py

そして、models.py の内容は次のようになりました。

class StudentInfo(models.Model):
    pic_id = models.IntegerField(null=True, blank=True)
    name = models.CharField(max_length=150, blank=True)
    hostel = models.CharField(max_length=9, blank=True)
    room = models.IntegerField(null=True, blank=True)
    branch = models.CharField(max_length=12, blank=True)
    id_no = models.CharField(max_length=36, blank=True)
    class Meta:
        db_table = u'student_info'

次に、syncdb の後にこれを実行すると、次のようになります。

python manage.py sqlall studentinfo
    BEGIN;
    CREATE TABLE `student_info` (
        `id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,
        `pic_id` integer,
        `name` varchar(150) NOT NULL,
        `hostel` varchar(9) NOT NULL,
        `room` integer,
        `branch` varchar(12) NOT NULL,
        `id_no` varchar(36) NOT NULL
    )
    ;
    COMMIT;

したがって、何かを取得しようとするとこのエラーが発生することを除いて、すべてが順調に進んでいるようです。

>>> from studentinfo.models import StudentInfo
>>> list=StudentInfo.objects.all()
>>> list
Traceback (most recent call last):
  File "<console>", line 1, in <module>
  File "/usr/lib/python2.7/dist-packages/django/db/models/query.py", line 69, in __repr__
    data = list(self[:REPR_OUTPUT_SIZE + 1])
  File "/usr/lib/python2.7/dist-packages/django/db/models/query.py", line 84, in __len__
    self._result_cache.extend(self._iter)
  File "/usr/lib/python2.7/dist-packages/django/db/models/query.py", line 273, in iterator
    for row in compiler.results_iter():
  File "/usr/lib/python2.7/dist-packages/django/db/models/sql/compiler.py", line 680, in results_iter
    for rows in self.execute_sql(MULTI):
  File "/usr/lib/python2.7/dist-packages/django/db/models/sql/compiler.py", line 735, in execute_sql
    cursor.execute(sql, params)
  File "/usr/lib/python2.7/dist-packages/django/db/backends/util.py", line 34, in execute
    return self.cursor.execute(sql, params)
  File "/usr/lib/python2.7/dist-packages/django/db/backends/mysql/base.py", line 86, in execute
    return self.cursor.execute(query, args)
  File "/usr/lib/python2.7/dist-packages/MySQLdb/cursors.py", line 174, in execute
    self.errorhandler(self, exc, value)
  File "/usr/lib/python2.7/dist-packages/MySQLdb/connections.py", line 36, in defaulterrorhandler
    raise errorclass, errorvalue
**OperationalError: (1054, "Unknown column 'student_info.id' in 'field list'")**

何がこれを引き起こしているのでしょうか?

4

2 に答える 2

8

sqlall空のデータベースで syncdb を実行した場合に作成されるものを示しています。から明らかなようDESCRIBEに、フィールドはありませんid。実際、主キーはまったくありません。これは非常に奇妙な設計です。SQL を介してフィールドを手動で追加する必要があります。

于 2012-06-28T15:02:14.090 に答える
2

レガシーデータベースで同じ状況が発生しました。

問題は、バニラ クエリセットが ID を取得してモデル オブジェクトを構築しようとすることです。私がやったことは、.values() を使用してクエリを実行することです。そうすれば、モデルの構築も ID もありません。

于 2014-08-29T17:37:25.557 に答える