❶ django 可以操作mysql函數么
第一步:下載mysql驅動
cmd進入創建好的django項目目錄:使用命令
?
1
pip install mysqlclient
等待安裝成功!
第二步:在settings.py中配置mysql連接參數(沒有mysql的先裝mysql)
?
1
2
3
4
5
6
7
8
9
10
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': '資料庫名(你得先在mysql中創建資料庫)',
'USER':'mysql用戶名(如root)',
'PASSWORD':'密碼(如123456789)',
'HOST':'域名(127.0.0.1或localhost)',
'PORT':'埠號(3306)',
}
}
第三步:在models.py中創建model類
?
1
2
3
4
5
from django.db import models
# Create your models here. 類似於MVC架構中的Model
class Article(models.Model):
title = models.CharField(max_length=60,default='title')
content = models.TextField(null=True)
第四步:根據model類創建資料庫表
1、cmd進入django項目路徑下
2、Python manage.py migrate #創建表結構,非model類的其他表,django所需要的
3、python manage.py makemigrations app名 #做數據遷移的准備
如:python manage.py makemigrations myblog myblog是我項目中的app名字
4、python manage.py migrate # 執行遷移,創建medel表結構
❷ django查詢mysql一次用不用關閉資料庫
SELECT url.url, count(url.url) nums, r.mac, rg.province_id, d.name from app_urlcollect AS url
RIGHT JOIN app_routers AS r ON url.router_mac=r.mac
RIGHT JOIN app_routergroups as rg ON r.router_groups_id=rg.id
RIGHT JOIN app_districts AS d ON d.id=rg.province_id WHERE rg.province_id='7644'
GROUP BY url.url
❸ python django查詢mysql表欄位的最大值
如果你的表是用模型建立的話,類似這樣
class Person(models.Model):
qq=models.CharField(max_length=100)
要取Person模型中的id最大值的話,可以使用a=Person.objects.latest('id'),這內樣取到的容是對應最大id的一個模型,a.id就是你要的值,然後a.qq就是最大id的qq號碼
❹ python+django能夠同時使用mongodb和mysql兩種數據
一樣配置,只需要配置好資料庫連接參數(一般配置在settings即可,或者單內獨的一個配置文件容),使用MySQLdb進行連接mysql即可,在需要展示頁面的viewspy處理好數據之間的交互即可(執行mysql語句,7788),然後整合傳到前端即可python+django能夠同時使用mongodb和mysql兩種數據
❺ django+python2.7 連接mysql資料庫取出一個欄位,在django自帶的伺服器控制台列印,是中文
模版里寫成 {{ name.0 }} 試試。
❻ Python3 django 使用model views查詢MySQL數據怎麼寫
from .models import MODEL(class name)
objs = MODEL.objects.get()或者filter()方法。
❼ django 用的mysql資料庫,刪除數據時索引也就隨之刪除了,索引就不規律了,如和能讓刪除數據時索引不變
這個id依然是規律的。
比如你原來有1、2、3、4、5、6、7、8、9個id號碼,結果刪內掉了3和7這兩個id。接下來你新建的容id會依然自動的從10開始,而不是你想像中認為的將3和7補齊。這是Django的默認規則。除非你手動指定id,前提是不產生沖突。
一般情況,不要去人為控制id這個自動欄位,而是自己設計一個專門的欄位做這方面的考慮,進行排序、過濾、索引等等方面的工作。
安利一個Django學習網站Django權威教程
❽ django連接已有 mysql
在settings中配置mysql庫的內容
DATABASES={
'default':{
'ENGINE':'django.db.backends.mysql',
'NAME':'djplatform',
'USER':'root',
'PASSWORD':'111111',
'HOST':'localhost',
'PORT':'3306',
}
}
如果已有數據表,但是沒有寫入到models.py中,可以運行:
python manage.py inspectdb > app/models.py
將現有數據表在內models中建模
這樣就容可以使用django model相關有方法對表進行讀取了
❾ 如何查看django與mysql資料庫連接
創建mysite目錄
django-admin.py startproject mysite這個命令作用是:這將創建在當前目錄創建一個mysite目錄
前提是從命令行上cd到你想儲存你代碼的目錄,然後生成各種子目錄.
首先需要注意的是文件目錄
這裡面的文件大致作用:
books這個 文件夾存放的是新建資料庫的各種信息
books/templates這個目錄下裝的是網頁的布局,當然這個網頁的布局就是show.html所提供
books/views.py定義函數,並且把show.html引入進去,文件內容如下:
from django.shortcuts import render,render_to_response
from django.template import loader
from books import models
# Create your views here.
def show(request):
# publisher_list = [{'name':"gongye",'city':'beijing'}]
publisher_list = models.Publisher.objects.all()
return render_to_response('show.html',{'publisher_list':publisher_list})
12345678910111213
books/models.py文件存放的是你所創建的資料庫,代碼如下:
#coding=utf-8
from __future__ import unicode_literals
from django.db import models
# Create your models here.
class Publisher(models.Model):
name = models.CharField(max_length = 30)
address = models.CharField(max_length = 50)
city = models.CharField(max_length = 60)
state_province = models.CharField(max_length = 30)
country = models.CharField(max_length = 50)
website = models.URLField()
# __unicode__這個函數用來返回某個值可以很好的用於查詢和admin界面的顯示
def __unicode__(self):
return self.name
class Author(models.Model):
first_name = models.CharField(max_length = 30)
last_name = models.CharField(max_length = 40)
email = models.EmailField(blank = True,verbose_name = 'e-mail')
def __unicode__(self):
return u'%s %s'%(self.first_name,self.last_name)
class Book(models.Model):
title = models.CharField(max_length = 100)
author = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher)
publication_date = models.DateField(blank = True,null = True)
def __unicode__(self):
return self.title
books下其他的文件就是在創建的過程中自己產生的.
website/templates文件里存放的是各種顯示的靜態網頁布局,這么多html文件,只要你在訪問測試的時候,埠號後面加上html的文件名字就行.比如,我要訪問templates/base.html文件,輸入網址:localhost:8000/base就可以.
website/settings.py文件是Django的設置文檔,裡面的INSTALLED_APPS添加多個應用,比如這裡面我九添加了books應用,代碼如下:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'books',
❿ python django models創建mysql資料庫表default、blank屬性失效
default屬性只在Django的來ORM模型中有效,不會自真正映射到資料庫里。要設置數據表的DEFAULT屬性,你可以手動修改makemigrations生成的腳本,或者去修改Django本身。
在db/backends/creation.py中找到如下欄位:
iff.primary_key:
field_output.append(style.SQL_KEYWORD('PRIMARYKEY'))eliff.unique:
field_output.append(style.SQL_KEYWORD('UNIQUE'))
在之後加上:
if(f.default!=models.fields.NOT_PROVIDED):
field_output.append(style.SQL_KEYWORD('DEFAULT'+str(f.default)))