当前位置: 首页 > 网络应用技术

Django数据表的哪个文件夹(2023年最新共享)

时间:2023-03-06 00:56:51 网络应用技术

  简介:许多朋友询问了有关Django数据表的相关问题。首席执行官在本文中注明将为您提供详细的答案,以供所有人参考。我希望这对每个人都会有所帮助!让我们一起看看!

  步骤1:

  在您的django项目目录中修改settings.py文件,如下所示:

  其中,“ db_name'对应于'name'

  命令行提示符创建的数据库名称:注意:在Django使用数据库之前,您必须创建数据库,否则将报告错误。

  还有与“密码”相对应的“ passwd”

  这是您在MySQL中创建的用户名和密码。如果您有多个,只需随便填写一个。“ host”和“ port”默认情况下不能填写。

  出色:使用用户名和密码登录到mySQL方法:

  首先,您需要输入MySQL/bin目录,也可以在.bash_profile中设置环境变量:

  路径=/usr/local/bin:/usr/bin:/bin:/sbin:/sbin:/usr/sbin:/usr/usr/local/sbin:/usr/local/mysql/5.6.22/bin/

  在提示中输入MySQL -U用户名-P,然后在返回后输入PassWD。

  第2步:

  然后使用Python Manage.py SynCDB在Manage.py路径中尝试。结果将表明您找不到MySQLDB模块。为什么,因为python manage.py syncdb命令正常工作:

  1.查找可能需要在项目目录中的stentaim_apps Metal of Attectings.py中续订的应用程序。

  2.在每个应用程序目录中找到Models.py(关系定义文件),并更新数据库中的更改。

  说了很多话,模块mysqldb在上一个错误中意味着什么?

  首先给图片,然后解释:

  因为Python用于定义模型中的关系。当然,必须在数据库中使用它来形成SQL语句,因此必须有一些功能模块。

  来将Python语句转换为SQL语句。如果您使用SQLITE,因为SQLITE和转换模块已由Python构建,直接使用直接使用不会是错误的

  错误。但是“ MySQL语句转换模块”需要您手动加载,这些模块放在MySQL-Python中。

  我用pip安装了它:

  安装后,请使用Python Manage.py SynCDB为正常。

  我使用的系统是OS X,以下是MySQL默认安装路径

  /USR/local/cellar/mysql/5.6.22/

  如果您想知道数据库文件的放置位置,则可以在MySQL_Config文件中检查LDATA变量。该变量的值是默认数据库文件夹存储路径。在我的系统中,mysql_config的完整路径是:

  /USR/local/cellar/mysql/5.6.22/bin/mysql_config

  1.创建项目

  运行以下命令来创建Django项目。项目名称是MySite:

  $ django- addmin.py startproject mysite

  创建的项目目录如下:

  我的网站

  e- manage.py

  t - 锰矿

  t- __init__.py

  在──设置.py

  s-或urls.py

  。─— wsgi.py

  1个目录,5个文件

  阐明:

  __init__.py:让Python将目录作为开发包所需的文件(即一组模块)。这是一个空文件,通常您不需要修改它。

  Manage.py:命令行工具允许您通过多种方式与Django项目进行交互。类型python manage.py帮助查看它可以做什么。您不需要编辑此文件;在此目录中为方便起见是纯粹的。

  settings.py:Django项目的设置或配置。

  urls.py:项目的URL路由设置。目前,它是空的。

  wsgi.py:wsgi Web应用程序服务器配置文件。有关更多详细信息,请检查如何使用WSGI部署

  接下来,您可以修改settings.py文件,例如:修改Lagansy_code,设置时区time_zone

  SIT_ID = 1

  lanking_code ='zh_cn'

  time_zone ='亚洲/上海'

  use_tz = true

  [时区]()功能在上方打开。您需要安装pytz:

  $ sudo pip安装pytz

  2.操作项目

  在运行项目之前,我们需要创建一个数据库和表结构。我在这里使用的默认数据库:

  $ python manage.py迁移

  执行操作:

  应用所有迁移:管理员,contenttypes,auth,sessions

  运行迁移:

  应用ContentTypes.0001_Initial ...确定

  应用auth.0001_initial ...确定

  应用管理员0001_Initial ...确定

  应用sessions.0001_initial ...好的

  然后开始服务:

  $ python manage.py runserver

  您将看到以下输出:

  执行系统检查...

  系统检查没有问题(0沉默)。

  2015-02 1月28日:08:33

  Django版本1.7.1,用户设置“ mysite.settings”

  启动开发服务器

  使用Control-C退出服务器。

  这将在端口8000启动本地服务器,只能从您的计算机连接和访问。现在服务器正在运行,现在可以访问Web浏览器。它开始工作。

  您还可以指定启动端口:

  $ python manage.py runserver 8080

  并指定的IP:

  $ python manage.py runserver 0.0.0.0:8000

  3.创建一个应用程序

  一个项目是更早创建并成功运营的。现在,要创建一个应用程序,应用程序等同于项目的子模块。

  在项目目录中创建一个应用程序:

  $ python manage.py startapp民意调查

  如果操作成功,您将在MySite文件夹下看到一个称为民意调查的文件夹。目录结构如下:

  民意调查

  t- __init__.py

  .- admin.py

  在移民

  │_ _- __init__.py

  s- models.py

  。—— tests.py

  s - 视图。

  1个目录,6个文件

  4.创建模型

  每个Django模型都从django.db.models.model继承

  模型中每个属性的每个属性代表数据库字段

  通过Django模型API

  在民意调查文件夹下打开Models.py文件。创建两个模型:

  导入日期

  来自django.db导入模型

  来自django.utils重要时区

  班级问题(Models.Model):

  Question_Text = model.Charfield(max_length = 200)

  pub_date = model.dateTimeField('Date已发布')

  def was_publish_recression(seld):

  返回self.pub_date = timezone.now()-dateTime.timedelta(天= 1)

  班级选择(Models.Model):

  问题=模型。Foreignkey(问题)

  choce_text = models.charfield(max_length = 200)

  投票= model.integerfield(默认= 0)

  然后修改inporthed_apps以在mySite/settings.py中添加民意调查:

  instasted_apps =((

  'django.contrib.admin',

  'django.contrib.auth',

  'django.contrib.contenttypes',

  'django.contrib.sessions',

  'django.contrib.messages',

  'django.contrib.staticfiles',

  “民意调查”,

  治愈

  添加新应用程序后,我们需要运行以下命令来告诉Django您的模型以进行更改。迁移数据库需要迁移:

  $ python manage.py makemigrations民意调查

  您将看到以下输出日志:

  “民意调查”的迁移:

  0001_Initial.py:

  - 创建模型选择

  - 创建模型问题

  -DD现场问题选择

  您可以从民意调查/迁移/0001_Initial.py查看迁移语句。

  运行以下语句,您可以查看迁移SQL语句:

  $ python manage.py sqlmigrate民意调查0001

  输出结果:

  开始;

  创建表“ polls_choice”(“ id”整数而不是null主键自动启动,“ choice_text” varchar(200)而不是null,“投票” integer而不是null);

  创建表“ polls_question”(“ id”整数而不是null主键自动启动,“ Question_Text” Varchar(200)不是null,“ pub_date” dateTime null)

  

  插入“ polls_choice__new”(“ phoce_text”,“票”,“ id”)选择“ polls_choice”中的“ choice_text”,“票数”,“投票”,“ id”

  丢弃表“ polls_choice”;

  Alter Table“ Polls_Choice__new”重命名为“ Polls_Choice”;

  在“ Polls_Choice”(“ Question_ID”)上创建索引Polls_choice_7aa0f6ee;

  犯罪;

  您可以运行以下命令以检查数据库是否存在问题:

  $ python manage.py检查

  再次运行以下命令以创建新添加的模型:

  $ python manage.py迁移

  执行操作:

  应用所有迁移:管理员,内容类型,民意调查,auth,会议

  运行迁移:

  应用民意调查。0001_Initial...好的

  总而言之,在修改模型时,您需要执行以下步骤:

  修改型号.py文件

  运行python manage.py makemigrations创建迁移语句

  运行python manage.py迁移并迁移模型更改为数据库

  您可以阅读django-admin.py文档以查看更多管理。

  创建模型后,我们可以通过Django提供的API进行测试。run以下命令输入Python Shell的交互模式:

  $ python manage.py shell

  这是一些测试:

  从polls.models导入问题,选择#导入我们刚刚编写的模型类。

  #系统中还没有问题。

  Question.Objects.all()

  []

  #创建一个新问题。

  #在默认设置文件中启用了对时区的支持,因此

  #Django用tzinfo for pub_date来实现DateTime。使用timezone.now()

  #而不是面团。dateTime.now(),它将做正确的事情。

  来自django.utils重要时区

  Q = Question(Question_text =“什么新功能?”,pub_date = timezone.now())

  #将对象保存到数据库中。您必须明确调用Save()。

  问:Save

  #现在它有一个ID。请注意,这可能会说“ 1”的“ 1”,具体取决于

  #您使用哪个数据库。那不是大事;这只是意味着你

  #数据库后端喜欢返回整数作为Python长整数

  #对象。

  Q.ID

  1

  #通过Python属性访问模型字段值。

  Q.question_text

  “什么是新的?”

  q.pub_date

  dateTime.dateTime(2012,2,26,13,0,0,0,775217,tzinfo = utc)

  #Change值通过更改属性,然后调用Save()。

  q.question_text =“怎么了?”

  问:Save

  #Objects.all()显示数据库中的所有问题。

  Question.Objects.all()

  [问题:问题对象]

  打印所有问题时,输出的结果是[问题:问题对象]。我们可以修改模型类以使其更容易理解。修改模型类:

  来自django.db导入模型

  班级问题(Models.Model):

  #...

  def __str __(self):#__unicode__ python 2

  返回self.question_text

  班级选择(Models.Model):

  #...

  def __str __(self):#__unicode__ python 2

  返回self.choice_text

  继续测试:

  从民意调查。模型导入问题,选择

  #确保我们的__str __()加法工作。

  Question.Objects.all()

  [问题:怎么了?]

  #Django提供了一个富含数据库的查找API,该API完全由

  #关键字参数。

  Question.Objects.Filter(ID = 1)

  [问题:怎么了?]

  Question.Objects.Filter(Question_text_Startswith ='What')

  [问题:怎么了?]

  #获取今年提出的问题。

  来自django.utils重要时区

  curren_year = timezone.now()。年

  Question.Objects.get(pub_date__year = current_year)

  问题:怎么了?

  #请求ID,这将引起例外。

  Question.Objects.get(ID = 2)

  Trackback(最近的最新电话):

  Em

  dotNotexist:不存在问题匹配查询。

  #主键查找是最合并的情况,因此Django提供了一个

  #主要钥匙精确查找的快捷方式。

  #跟随者与Question.objects.get(ID = 1)相同。

  Question.Objects.get(PK = 1)

  问题:怎么了?

  #确保我们的自定义方法有效。

  Q = Question.Objects.get(PK = 1)

  #给出一些选择。创建呼叫构造一个新的

  #选择对象,执行插入语句,将选择添加到集合

  可用选择的#并返回新选择对象。Django创建

  #一套持有外国关系的“另一面”

  #(例如,一个问题的选择)可以通过API访问。

  Q = Question.Objects.get(PK = 1)

  #从相关对象集中显示任何选择 - 到目前为止无。

  q.choice_set.all()

  []

  #创建三个选择。

  Q.CHOICE_SET.CREATE(choce_text ='不多',票数= 0)

  选择:不多

  Q.CHOICE_SET.CREATE(choce_text ='the Sky',投票= 0)

  选择:天空

  c = q.choice_set.create(choce_text ='再次黑客入侵',票数= 0)

  #选择对象可以访问其相关问题对象。

  C.问题

  问题:怎么了?

  #和VICE,反之亦然:问题对象可以访问选择对象。

  q.choice_set.all()

  [选择:不是泥土,选择:天空,选择:再次入侵]

  q.choice_set.count()

  3

  #API自动食品遵循您需要的相关船。

  #使用面团下划线选择相关职位。

  #这是您想要的深层层次的工作。没有限制。

  #找到今年Pub_date的任何问题的所有选择

  #(重用我们上面创建的“ Current_Year”变量)。

  choce.objects.filter(问题__pub_date__year = current_year)

  [选择:不是泥土,选择:天空,选择:再次入侵]

  #让我们删除其中一个选择。为此使用delete()。

  c = q.choice_set.filter(choce_text__startswith ='Just Hacking')

  c.delete()

  以上测试涉及与Django Orm相关的知识。有关详细信息,请参阅Django中的ORM。

  5.管理管理员

  Django具有构建-Django管理员背景管理界面的出色特征,对于管理人员而言,它很方便地添加和删除网站的内容。

  新项目系统已为我们设置了背景管理功能。请参阅mySite/settings.py:

  instasted_apps =((

  'django.contrib.admin',#

  'django.contrib.auth',

  'django.contrib.contenttypes',

  'django.contrib.sessions',

  'django.contrib.messages',

  'django.contrib.staticfiles',

  '我的网站',

  治愈

  同时,添加了进入背景管理的URL。您可以在MySite/urls.py中查看它:

  url(r'^admin/',infulude(admin.site.urls)),#可以使用SET URL进入网站的背景

  接下来,我们需要创建管理用户来登录到管理背景管理接口:

  $ python manage.py createSuperuse

  用户名(留空白以使用“六月”):管理员

  电子邮件地址:

  密码:

  密码(再次):

  超级用户成功创建了。

  总结

  最后,查看项目目录结构:

  我的网站

  Q - db.sqlite3

  e- manage.py

  t - 锰矿

  │_ _- __init__.py

  │e ─—设置.py

  │u - urURLS.PY

  │s-wsgi.py

  S - 民意调查

  │_ _- __init__.py

  │d - 管理

  │i - 移民

  ││├├─-0001_Initial.py

  ││├─..__Init__.py

  │o - models.py

  │e - ─-模板

  民意调查

  ││├├─detail.html

  ││├ - index.html

  thml

  │e - tests.py

  │u - urURLS.PY

  │i - ─视图。

  L ─—模板

  在─管理员

  _ - base_site.htm

  通过上面的介绍,我对Django的安装,操作以及如何创建视图以及如何创建视图和模型有了清晰的了解。接下来,您可以彻底了解Django的自动化测试,持久性,中间件和国际化的知识。

  不用找了

  外部manage.py用于管理您创建的MySite项目,即MySite文件夹和Manage.py是整个项目。

  至于外面的米特人,它只是一个用于存储项目位置的文件夹。它与该项目无关。这个mysite可以是任何名字。您可以随便更改它

  在Django中,管理数据库类似于SQLARCHEMY,并通过ORM框架实现。所有数据库的建立均在Model.py中实现。

  首先查看如何创建一个表:

  A。首先定义类,继承模型。模型,然后根据要求定义参数。这些参数的类型和变量将在以后进一步说明

  模型

  来自django.db导入模型

  类UserInfo(models.model):

  用户名= models.charfield(max_length = 32)

  密码= models.charfield(max_length = 64)

  b。注册应用程序

  settings.py

  instasted_apps = [[[

  ‘django.contrib.admin’,

  ‘django.contrib.auth’,

  ‘django.contrib.contenttypes',

  'django.contrib.sessions',

  ‘django.contrib.messages',

  ‘django.contrib.staticfiles’,

  “ app01”,

  这是给予的

  C。execute命令。第一个命令将生成一个初始化文件,第二个命令将生成相应的表

  python manage.py makemigrations

  python manage.py迁移

  这样,PyCharm随附的SQLite数据库中成功生成了App01_userinfo的表。该表将以自我信息为主键,而我们的其他两个字段由我们通过类创建。

  d。如果要使用MySQL,因为Django默认使用MySQLDB模块,因此在版本3.0中不存在此错误,因此它将直接报告错误。我们需要更改为PymySQL的模块。该方法如下:

  将以下代码添加到同名文件夹的文件夹下的__init__文件:

  导入pymysql

  pymysql.install_as_mysqldb()

  2.查询添加,删除,更改单个表的查询

  查询

  获取所有结果,获得的结果是类似QuerySet列表的对象。每个元素本身都是一个对象,包括ID,名称,密码和其他属性。

  obj = model.userinfo.objects.all()

  querySet [UserInfo:UserInfo对象,UserInfo:UserInfo对象,UserInfo:UserInfo对象,UserInfo:UserInfo Object,userInfo:userInfo:userInfo Object]

  它可以通过过滤器过滤,这相当于SQL的语句,因为结果也是querySet,因此您需要使用第一个()来获取第一个值

  obj = model.userinfo.objects.filter(id = nid).first()

  增加

  models.userinfo.objects.create(用户名= u,password = p,user_group_id = 3)

  删除,您可以根据过滤器删除它

  models.userinfo.objects.filter(id = nid).delete()

  有两种常见的修改方法

  第一条方法

  models.userinfo.objects.filter(id = nid).update(用户名= u,password = p)

  第二种方式

  obj = model.userinfo.objects.filter(id = nid)

  obj.username = u

  obj.save()

  C:用户用户名AppData通常具有三个文件夹,即本地,locallow,漫游。简而言之,它们都用于存储软件配置文件和临时文件。可以删除该文件夹。例如,如果您在AppD中安装Photoshopcs5,则可以在AppD ...中安装Photoshopcs5。

  我在Internet上搜索了很多文档,主要是Apache环境中的解决方案。我配置了NGINX服务器,因此根据Apache解决方案提示并探索了该方法,我终于得出结论,这里有3个步骤(假设管理员已配置为Admin,登录系统):

  1.为静态静态文件修改static_root的物理路径。例如,我的静态文件存储在/home/user/www/static中。首先在www目录中创建一个静态文件夹,最后修改settings.py.static_root指示/home/home/user/www/static。

  2.运行python manage.py collectstatic命令,该命令将将必要的静态文件从django资源软件包复制到static_root指示的静态文件夹,其中包括样式表(样式)和图片(图像)和图片(图像)以及图片(图像)和图片。Script(JS),等。

  在这里提示,如果您不执行步骤1,则直接运行此命令将导致以下错误提示(最后几行):

  

  self.storage = get_storage_class(settings.staticfiles_storage)()()()

  文件“/usr/lib/python2.7/dist-packages/django/contrib/statics/storage.py”,第23行,in __init___

  

  实际上,已提示您需要配置static_root文件(使用static_root设置恢复staticfiles应用程序)。

  

  服务器 {

  #……其余内容有点

  位置 /静态{

  root/home/user/www;

  }

  }

  如果您不在此处修改它,我就会对其进行测试,好像似乎将处理已移交给Django,但是Django仍然找不到页面(404)。

  完成上述三个步骤后,重新加载相应的设置:

  Indoke-rc.d Uwsgi重新加载

  nginx -s重新加载

  好吧,基本上解决了问题,如果有任何不当的地方,请指出。

  结论:以上是首席CTO注释为每个人编制的数据表的全部内容。哪个文件夹是Django的所有内容,感谢您花时间阅读此网站,我希望为您提供帮助,更多有关Django数据表的数据表Aredon aredon nove nove noving nove noving nove nove finding nove nove nove nove tocles of Django的数据表。