我正在尝试将mongodb与django连接,但我收到此错误
ImproperlyConfigured: 'djongo' isn't an available database backend.
Try using 'django.db.backends.XXX', where XXX is one of:
'mysql', 'oracle', 'postgresql_psycopg2', 'sqlite3'
我看过帖子,但他们都老了,没帮我。我用studio 3T创建了mongodb数据库,数据库名是New DataBase用户是gsc-30310端口是27017主机是localhost
我使用的版本是:
python3
Django==2.1.1
mongoengine==0.15.3
pymongo==3.7.1
这是我的settings.py文件,请告诉我如何设置新版本的django和python 3.谢谢
"""
Django settings for RestUserAPI project.
Generated by 'django-admin startproject' using Django 2.1.2.
For more information on this file, see
https://docs.djangoproject.com/en/2.1/topics/settings/
For the full list of settings and their values, see
https://docs.djangoproject.com/en/2.1/ref/settings/
"""
import os
import mongoengine
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/
# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '3==2yxbjdvt+hkqm#*%s7cs4g(_+cus9pdup%bxd*uk03g^&w%'
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
ALLOWED_HOSTS = []
# Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
#RestFrameWork
'rest_framework',
]
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
ROOT_URLCONF = 'RestUserAPI.urls'
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
WSGI_APPLICATION = 'RestUserAPI.wsgi.application'
# Database
# https://docs.djangoproject.com/en/2.1/ref/settings/#databases
DATABASES = {
'default': {
#'ENGINE': 'django.db.backends.sqlite3',
#'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
'ENGINE' : '',
'NAME' : 'local',
'USER' : 'gsc-30310',
'PASSWORD': 'gsc-30310',
'HOST': 'localhost',
'PORT': '27017',
}
}
# _MONGODB_USER = 'gsc-30310'
# _MONGODB_PASSWD = 'gsc-30310'
# _MONGODB_HOST = '127.0.0.1'
# _MONGODB_NAME = 'NewDataBase'
# _MONGODB_DATABASE_HOST = \
# 'mongodb://%s:%s@%s/%s' \
# % (_MONGODB_USER, _MONGODB_PASSWD, _MONGODB_HOST, _MONGODB_NAME)
#
# mongoengine.connect(_MONGODB_NAME, host=_MONGODB_DATABASE_HOST)
AUTHENTICATION_BACKENDS = (
'mongoengine.django.auth.MongoEngineBackend',
)
# Password validation
# https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators
AUTH_PASSWORD_VALIDATORS = [
{
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
},
]
# Internationalization
# https://docs.djangoproject.com/en/2.1/topics/i18n/
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.1/howto/static-files/
STATIC_URL = '/static/'
REST_FRAMEWORK = {
'DEFAULT_PERMISSION_CLASSES': [
'rest_framework.permissions.DjangoModelPermissionsOrAnonReadOnly'
],
'DEFAULT_RENDERER_CLASSES': (
'rest_framework.renderers.JSONRenderer',
'rest_framework.renderers.BrowsableAPIRenderer',
),
# 'DEFAULT_PARSER_CLASSES': (
# 'rest_framework.parsers.JSONParser',
# )
'DEFAULT_AUTHENTICATION_CLASSES':[
'rest_framework.authentication.SessionAuthentication',
#'rest_framework.authentication.BasicAuthentication'
],
'DEFAULT_PERMISSION_CLASSES':[
'rest_framework.permissions.AllowAny',
]
}
在django视图中使用pymongo:
client = pymongo.MongoClient(MONGO_URI)
mongodb = client[MONGO_DB_NAME]
...
class MongoClassView(View):
def post(request):
...
mapped_data = {'name': 'John'}
mongodb.get_collection('mycollection').insert(mapped_data)
return JsonResponse({})
希望这可以帮助
您可以尝试以下步骤将django 2.0或更多版本与MongoDB数据库连接:
1)为django 2.0安装另一个版本
pip install -e git+https://github.com/MongoEngine/django-mongoengine.git#egg=django-mongoengine
2)在您的设置文件中添加这些:
from mongoengine import *
'django_mongoengine', // Add this line to installed app
MONGODB_DATABASES = {
"default": {
"name": '<db_name>',
"host": 'localhost',
"password": '',
"username": '',
"tz_aware": True, # if you using timezones in django (USE_TZ = True)
},
}
您可以找到查询数据库here的详细信息
Django适用于PostGreSQL,MySQL等关系数据库。每个django设置都需要使用'default'配置定义数据库配置,它还需要数据库各自的引擎,如PostGreSQL的psycopg2,MySQL的mysqlclient - 如果你有多个数据库配置,那么你需要使用数据库路由器检查here作为参考。对于MongoDB - 它是一个NoSql数据库,Django官方不支持如果你真的需要使用MongoDB在视图中创建一个mongoengine配置,你可以在settings.py中定义mongo凭据
首先感谢您在这个问题上的答案和支持。
我同意Sanchit和shreesh katti的答案,我们可以使用mongoclient和mongoengine连接MongoDB,两者都很好用。
我找到了另一种方式,有一个开源项目djongo
,我使用djongo
连接MongoDB
数据库。 djongo
的主要好处是它可以让你使用django
提供的所有东西(例如models.Model)。
这里是djongo
GitHub页面https://github.com/nesdis/djongo的链接
这是我们需要使用djongo settings.py的设置
DATABASES = {
'default': {
'ENGINE': 'djongo',
'NAME': 'MyDB',
}
}
使用mongoengine和djongo连接。在settings.py文件中进行以下更改
mongoengine.connect(
db=config.main_db,
host=config.host,
#username=config.username_admin,
#password=config.password_admin,
#authentication_source=config.authSource_admin,
#authentication_mechanism=config.authenticationMechanisms)
DATABASES = {
'default': {
'ENGINE': 'djongo',
'NAME': config.main_db,
# 'USER': config.username_admin,
# 'PASSWORD': config.password_admin,
# 'HOST': config.host,
# 'PORT': config.port,
}
}