質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

8688閲覧

python + DjangoのDB(SQLServer)接続方法について

sirosiro346

総合スコア28

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

1クリップ

投稿2017/05/11 12:59

###前提・実現したいこと
python + DjangoでWEB開発を行っております。
DjangoにおけるSQLServerの接続方法がわからず困っております。
以下サイトを参考にしておりますがうまくいきません。
ご存知の方おりましたら、ご教授いただけますでしょうか。
https://django-mssql.readthedocs.io/en/latest/quickstart.html#installation

###現在の状況
以下サイトを参考にsetting.pyを変更しています。
https://django-mssql.readthedocs.io/en/latest/quickstart.html#installation

[参考URL上のsetting.py]

DATABASES = { 'default': { 'NAME': 'my_database', 'ENGINE': 'sqlserver_ado', 'HOST': 'dbserver\\ss2012', 'USER': '', 'PASSWORD': '', } }

[実際に設定しているsetting.py]

DATABASES = { 'default': { 'NAME': 'LibDB', 'ENGINE': 'sqlserver_ado', 'HOST': 'NYANSHIROU\SQLSERVER2014', 'USER': 'sa', 'PASSWORD': 'XXXXXXXXXXXX' } } ※XXXXXXXXXXXX にはパスワードが入っています

###発生している問題・エラーメッセージ

The above exception was the direct cause of the following exception: Traceback (most recent call last): File "C:\ProgramData\Anaconda3\lib\site-packages\django\utils\autoreload.py", line 226, in wrappe r fn(*args, **kwargs) File "C:\ProgramData\Anaconda3\lib\site-packages\django\core\management\commands\runserver.py", l ine 124, in inner_run self.check_migrations() File "C:\ProgramData\Anaconda3\lib\site-packages\django\core\management\base.py", line 437, in ch eck_migrations executor = MigrationExecutor(connections[DEFAULT_DB_ALIAS]) File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\migrations\executor.py", line 20, in _ _init__ self.loader = MigrationLoader(self.connection) File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\migrations\loader.py", line 52, in __i nit__ self.build_graph() File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\migrations\loader.py", line 203, in bu ild_graph self.applied_migrations = recorder.applied_migrations() File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\migrations\recorder.py", line 65, in a pplied_migrations self.ensure_schema() File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\migrations\recorder.py", line 52, in e nsure_schema if self.Migration._meta.db_table in self.connection.introspection.table_names(self.connection.c ursor()): File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\backends\base\base.py", line 231, in c ursor cursor = self.make_debug_cursor(self._cursor()) File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\backends\base\base.py", line 204, in _ cursor self.ensure_connection() File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\backends\base\base.py", line 199, in e nsure_connection self.connect() File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\utils.py", line 94, in __exit__ six.reraise(dj_exc_type, dj_exc_value, traceback) File "C:\ProgramData\Anaconda3\lib\site-packages\django\utils\six.py", line 685, in reraise raise value.with_traceback(tb) File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\backends\base\base.py", line 199, in e nsure_connection self.connect() File "C:\ProgramData\Anaconda3\lib\site-packages\django\db\backends\base\base.py", line 171, in c onnect self.connection = self.get_new_connection(conn_params) File "C:\ProgramData\Anaconda3\lib\site-packages\sqlserver_ado\base.py", line 233, in get_new_con nection conn = Database.connect(**conn_params) File "C:\ProgramData\Anaconda3\lib\site-packages\sqlserver_ado\dbapi.py", line 199, in connect mask_connection_string_password(connection_string) django.db.utils.OperationalError: (com_error(-2147352567, '例外が発生しました。', (0, 'ADODB.Connec tion', 'プロバイダーが見つかりません。正しくインストールされていない可能性があります。', 'C:\\WINDO WS\\HELP\\ADO270.CHM', 1240655, -2146824582), None), 'Error opening connection: DATA SOURCE=NYANSHI ROU\\SQLSERVER2014;Initial Catalog=LibDB;UID=sa;PWD=******;PROVIDER=sqlncli10;DataTypeCompatibility =80;MARS Connection=True')

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

こんばんは。SQL Serverが必須条件でなければ・・・なのですが、

PostgreかMySQLにデータベースを代えてはいかがでしょうか??無料ですし、データ量が大きくなっても対応可能ですし、特にDjangoの開発チームはPostgreを公式に推奨していたと思います。(たしか)

データベースを変えれば同じ機能を実現できつつ上記のエラーはなかったことにできます。

投稿2017/05/18 11:57

k_mawa82

総合スコア234

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sirosiro346

2017/05/19 23:38

ありがとうございます。 また返信が遅れてしまいすみません。 会社でSQLServerを使っている都合上、その連携部分も知りたかったのですが、ご指摘いただいたように一旦どちらかのDBにて実施してみようと思います! ありがとうございました。
k_mawa82

2017/05/20 15:15

よかったです!こちらこそうれしいです!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問