我需要使用django ORM的最小文件

时间:2015-12-29 21:45:51

标签: python django django-orm

我有python模块用于做一些事情,我需要在数据库中保存一些项目。

Currenlt我正在使用原始sql来插入数据。但我想使用django ORM。

我不需要任何网址,视图等我想要的只是我可以创建模型然后应该能够保存它像

user.save()

现在我不想在那里有不必要的文件和数据。但我不确定我需要哪些文件。我需要吗

settings.py
urls.py
views.py
app folder.

是否可以只有models.py,然后在设置DATABASE config

我是否还需要创建一个应用程序

2 个答案:

答案 0 :(得分:6)

你需要settings.py。您不需要urls.py或views.py。您将需要一个应用程序文件夹,并在settings.py中将该应用程序置于INSTALLED_APPS下。虽然有一种手动发现应用程序的方法,但它可能比您希望进入更多的工作。

您还需要运行迁移,并在此过程中创建迁移目录和文件。

在app目录中,你真正需要的只是__init__.py文件,迁移目录和models.py文件

在models.py中,有“来自django.db导入模型”,然后让你的模型继承自models.Model。

完成所有工作,你有一个非常准确的Django设置,用于使用你的模型与数据库交互

修改

为了解决这个问题,我开始了一个新的Django 1.9项目并开始屠杀settings.py文件,直到我破坏了一些东西。这就是我的开始:

"""
Django settings for Test project.

Generated by 'django-admin startproject' using Django 1.9.

For more information on this file, see
https://docs.djangoproject.com/en/1.9/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.9/ref/settings/
"""

import os

# 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/1.9/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'yp0at6d_bpr5a^j$6$#)(17tj8m5-^$p773lc6*jy%la!wu5!i'

# 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',
    'modeltest',
]

MIDDLEWARE_CLASSES = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
ROOT_URLCONF = 'Test.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 = 'Test.wsgi.application'


# Database
# https://docs.djangoproject.com/en/1.9/ref/settings/#databases

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}


# Password validation
# https://docs.djangoproject.com/en/1.9/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/1.9/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/1.9/howto/static-files/

STATIC_URL = '/static/'

我还制作了一个示例github repo,以便您可以探索最小化设置的样子。 https://github.com/RobertTownley/BarebonesDjango

我能够在不破坏数据库交互的情况下完成的事情(只要我一次完成所有操作,并且在第一次运行迁移之前):

  1. 从我的“modeltest”应用
  2. 中删除管理员,观看和测试
  3. 删除wsgi.py(假设它永远不会看到生产,也不会用于实际运行Web服务器)
  4. 从urls.py中删除字面上的所有内容并将其保留为空白文件(不幸的是,settings.py期望ROOT_URLCONF指向某个内容)
  5. 从settings.py中删除所有MIDDLEWARE_CLASSES,以及TEMPLATES,WSGI_APPLICATION,所有国际化功能,DEBUG,ALLOWED_HOSTS和所有评论:)
  6. 因此,在本实验结束时,我可以使用看起来像这样的settings.py文件与我的准系统模型(包括添加新字段)进行交互:

    import os
    BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
    SECRET_KEY = 'v7j%&)-4$(p&tn1izbm0&#owgxu@w#%!*xn&f^^)+o98jxprbe'
    INSTALLED_APPS = ['modeltest']
    ROOT_URLCONF = 'BarebonesTest.urls'
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.sqlite3',
            'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
        }
    }
    

    如果我知道sqlitedb所需位置的确切文件路径,或切换到postgres / mysql,我可以摆脱导入语句和BASE_DIR,将我的settings.py行总数减少到4个实质行( db setting,root_url,installed_apps和secret_key)

    我喜欢被证明是错的(学习很有趣),但我认为你不能得到比这更小的settings.py文件:)

答案 1 :(得分:0)

对于Django 1.9,我只需要运行django-admin startproject:settings.py后只有3个变量和manage.py的文件。这两个,加上来自wsgi.py的一段代码,以及一些基本的目录结构元素,可以让您使用独立的ORM设置。实际上,如果您不想进行迁移,可以去掉manage.py。

以下是您的操作方式,以及GitHub为您自己播放的链接。

项目结构:

├── data
│   ├── __init__.py
│   ├── migrations
│   │   └── __init__.py
│   └── models.py
├── main.py
├── manage.py
└── settings.py

data目录和迁移目录包含空__init__.py个文件。示例models.py文件如下所示:

from django.db import models

class User(models.Model):
    name = models.CharField(max_length=255)
    email = models.EmailField(max_length=255)

manage.py文件是典型的Django manage.py文件。如果您从新的os.environ.setdefault命令复制它,请务必更改django-admin startproject中的设置参数:

#!/usr/bin/env python
import os
import sys

if __name__ == "__main__":
    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
    from django.core.management import execute_from_command_line
    execute_from_command_line(sys.argv)

settings.py文件需要3个设置:DATABASES,INSTALLED_APPS和SECRET_KEY。请参阅不是SQLite的DB的Django文档:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': 'sqlite.db',
    }
}

INSTALLED_APPS = (
    'data',
    )

SECRET_KEY = 'REPLACE_ME'

真正的诀窍是main.py,这是您可以针对模型进行编码的地方。显然你必须使用wsgi.py中的一些代码来解决这两行问题:

from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()

这是一个示例main.py:

# Django specific settings
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")

### Have to do this for it to work in 1.9.x!
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
#############

# Your application specific imports
from data.models import *

#Add user
user = User(name="someone", email="someone@example.com")
user.save()

# Application logic
first_user = User.objects.all()[0]

print(first_user.name)
print(first_user.email)

This project以及this post是我找到答案的有用起点,我的Django 1.9工作代码的拉取请求已合并,因此您现在可以从masnun的repo中获取代码。如果您知道更好的方法,请提交拉取请求。