python Django連接MySQL數(shù)據(jù)庫做增刪改查
1、下載安裝MySQLdb類庫
http://www.djangoproject.com/r/python-mysql/
2、修改settings.py 配置數(shù)據(jù)屬性
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
'NAME': 'djangodb', # Or path to database file if using sqlite3.
# The following settings are not used with sqlite3:
'USER': 'root',
'PASSWORD': 'root',
'HOST': '127.0.0.1', # Empty for localhost through domain sockets or '127.0.0.1' for localhost through TCP.
'PORT': '3306', # Set to empty string for default.
}
}
修改完后進(jìn)入DOS進(jìn)入項(xiàng)目目錄下執(zhí)行python manage.py shell命令啟動交互界面輸入一下代碼驗(yàn)證數(shù)據(jù)庫配置是否成功。沒報(bào)錯則成功!
>>> from django.db import connection
>>> cursor = connection.cursor()
3、創(chuàng)建一個Django app
一個項(xiàng)目中包含一個或多個這樣的app。app可以理解為一塊功能集合。比如產(chǎn)品管理模塊就包含增刪該查等功能,可以把產(chǎn)品管理叫做一個app。每個Django app都有獨(dú)立的models,views等,易移植和被復(fù)用。
DOS進(jìn)入項(xiàng)目目錄 執(zhí)行 python manage.py startapp products生成目錄文件如下:
products/
__init__.py
models.py
tests.py
views.py
4、編寫models
from django.db import models
# Create your models here.
class Company(models.Model):
full_name = models.CharField(max_length=30)
address = models.CharField(max_length=50)
tel = models.CharField(max_length=15,blank=True)
class Product(models.Model):
product_name = models.CharField(max_length=30)
price = models.FloatField()
stock = models.IntegerField(max_length=5)
company = models.ForeignKey(Company)
5、模型安裝(修改settings.py)
INSTALLED_APPS = (
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.staticfiles',
# Uncomment the next line to enable the admin:
'django.contrib.admin',
# Uncomment the next line to enable admin documentation:
'django.contrib.admindocs',
'DjangoMysqlSite.products',
)
采用 python manage.py validate 檢查模型的語法和邏輯是否正確。
沒有錯誤則執(zhí)行 python manage.py syncdb創(chuàng)建數(shù)據(jù)表。
現(xiàn)在你可以看到你的數(shù)據(jù)庫除了生成了products_company,products_product外還創(chuàng)建了其它好幾個表,這些是django管理后臺所需表暫不管。
6、簡單的增刪改查
進(jìn)入python manage.py shell
from DjangoMysqlSite.products.models import Company
>>> c = Company(full_name='集團(tuán)',address='杭州西湖',tel=8889989)
>>> c.save()
>>> company_list = Company.objects.all()
>>> company_list
>>> c = Company.objects.get(full_name="集團(tuán)")
>>> c.tel = 123456
>>> c.save()
>>> c = Company.objects.get(full_name="集團(tuán)")
>>> c.delete()
#刪除所有
>>> Company.objects.all().delete()
- django執(zhí)行原生SQL查詢的實(shí)現(xiàn)
- 在Django的模型中執(zhí)行原始SQL查詢的方法
- Django讀取Mysql數(shù)據(jù)并顯示在前端的實(shí)例
- Django配置MySQL數(shù)據(jù)庫的完整步驟
- Django1.7+python 2.78+pycharm配置mysql數(shù)據(jù)庫教程
- Python的Django框架中使用SQLAlchemy操作數(shù)據(jù)庫的教程
- Django+mysql配置與簡單操作數(shù)據(jù)庫實(shí)例代碼
- Python+Django+MySQL實(shí)現(xiàn)基于Web版的增刪改查的示例代碼
- Django重裝mysql后啟動報(bào)錯:No module named ‘MySQLdb’的解決方法
- Django使用Mysql數(shù)據(jù)庫已經(jīng)存在的數(shù)據(jù)表方法
- Linux下安裝Python3和django并配置mysql作為django默認(rèn)服務(wù)器方法
- Django使用原生SQL查詢數(shù)據(jù)庫詳解
相關(guān)文章
Pytorch+PyG實(shí)現(xiàn)EdgeCNN過程示例詳解
這篇文章主要為大家介紹了Pytorch+PyG實(shí)現(xiàn)EdgeCNN過程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04Python將多個圖像合并輸出的實(shí)現(xiàn)方法
這篇文章主要介紹了Python將多個圖像合并輸出的實(shí)現(xiàn)方法,本文介紹了兩種將多個圖像合并為一個輸出的方法:使用PIL庫或使用OpenCV和NumPy,這些庫都可以使用Python中的簡單語法和少量的代碼來完成此任務(wù),需要的朋友可以參考下2023-06-06python常用操作之使用多個界定符(分隔符)分割字符串的方法實(shí)例
在使用Python處理字符串的時候,有時候會需要分割字符,下面這篇文章主要給大家介紹了關(guān)于python常用操作之使用多個界定符(分隔符)分割字符串的相關(guān)資料,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01python sitk.show()與imageJ結(jié)合使用常見的問題
這篇文章主要介紹了python sitk.show()與imageJ結(jié)合使用常見的問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04python3.7.2 tkinter entry框限定輸入數(shù)字的操作
這篇文章主要介紹了python3.7.2 tkinter entry框限定輸入數(shù)字的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05