1

ローカル マシンから Google Cloud SQL サービスに接続できます。

    $ python manage.py syncdb

このコマンドは、django モデルを使用して、必要なデータベース テーブルを Google Cloud SQL に作成します。(私のデータベース設定は Cloud SQL データベース設定を指しています)しかし、dbshel​​lコマンドを発行するとエラーが発生します。

$ python manage.py dbshell

Traceback (most recent call last):
  File "manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/__init__.py", line 443, in execute_from_command_line
    utility.execute()
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/__init__.py", line 382, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/base.py", line 196, in run_from_argv
    self.execute(*args, **options.__dict__)
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/base.py", line 232, in execute
    output = self.handle(*args, **options)
  File "/usr/local/lib/python2.7/dist-packages/django/core/management/commands/dbshell.py", line 21, in handle
    connection.client.runshell()
  File "/usr/local/google_appengine/google/storage/speckle/python/django/backend/client.py", line 47, in runshell
    from google.storage.speckle.python.tool import google_sql
  File "/usr/local/google_appengine/google/storage/speckle/python/tool/google_sql.py", line 53, in <module>
    from grizzled import db
ImportError: No module named grizzled

Cloud SQL で ./manage.py dbshel​​l を実行できますか?

4

1 に答える 1

0

同じ問題がありました。必要な google_appengine ライブラリを PYTHONPATH に追加することで解決しました。

export PYTHONPATH="$PYTHONPATH:/path/to/google_appengine:/path/to/google_appengine/lib/django_1_5:/path/to/google_appengine/lib/grizzled:/path/to/google_appengine/lib/prettytable:/path/to/google_appengine/lib/sqlcmd:/path/to/google_appengine/lib/enum"

Cloud SQL に接続するたびにこれを行う必要があります。

于 2013-11-02T21:03:24.790 に答える