Django資料庫類庫MySQLdb使用詳解

来源:https://www.cnblogs.com/programmer123/archive/2019/10/23/11729815.html
-Advertisement-
Play Games

Django項目要操作資料庫,首先要和資料庫建立連接,才能讓程式中的數據和資料庫關聯起來進行數據的增刪改查操作 Django項目預設使用mysqldb模塊進行和mysql資料庫之間的交互操作。 下麵看下Django進行資料庫操作的步驟: 1. 修改settings.py 配置數據項 配置項參數用法: ...


Django項目要操作資料庫,首先要和資料庫建立連接,才能讓程式中的數據和資料庫關聯起來進行數據的增刪改查操作

Django項目預設使用mysqldb模塊進行和mysql資料庫之間的交互操作。

下麵看下Django進行資料庫操作的步驟:

1. 修改settings.py 配置數據項

 

 

 

配置項參數用法:

ENGINE : 指定資料庫驅動,不同的資料庫這個欄位不同,下麵是常見的集中資料庫的ENGINE的寫法:

django.db.backends.postgresql  # PostgreSQL  

django.db.backends.mysql       # mysql  

django.db.backends.sqlite3     # sqlite  

django.db.backends.oracle      # oracle  

NAME: 指定的資料庫名,如果是sqlite的話,就需要填資料庫文件的絕對位置

USER: 資料庫登錄的用戶名,mysql一般都是root

PASSWORD:登錄資料庫的密碼,必須是USER用戶所對應的密碼

HOST: 由於一般的資料庫都是C/S結構的,所以得指定資料庫伺服器的位置,我們一般資料庫伺服器和客戶端都是在一臺主機上面,所以一般預設都填127.0.0.1

PORT:資料庫伺服器埠,mysql預設為3306

HOST和PORT都可以不填,使用預設的配置,但是如果你有更改預設配置的話,就需要填入更改後的

2. 安裝資料庫驅動

配置完這,下麵就需要裝python連接mysql資料庫的驅動程式,首先,需要安裝mysql的開發包,在shell,裡面運行:                                                                                                             如果沒有安裝,那就安裝把:                                                                                                                                                                                           安裝好後,啟動django                                                                                          

 

 如果沒有出現報錯,則表明配置正常,然後在新的shell運行:

輸入以下命令:

 

 

 

 如果沒有報錯,則就表明安裝成功,你可以盡情使用django的資料庫功能了

3. 創建一個Django app

一個項目中包含一個或多個這樣的app。app可以理解為一塊功能集合。比如產品管理模塊就包含增刪該查等功能,可以把產品管理叫做一個app。每個Django app都有獨立的models,views等,易移植和被覆用。

DOS進入項目目錄 執行 python manage.py startapp products生成目錄文件如下:

代碼如下:

4. 編寫models

代碼如下:

5. 模型安裝(修改settings.py)

代碼如下: 

採用 python manage.py validate 檢查模型的語法和邏輯是否正確。

沒有錯誤則執行 python manage.py syncdb創建數據表。

現在你可以看到你的資料庫除了生成了products_company,products_product外還創建了其它好幾個表,這些是django管理後臺所需表暫不管。

6、簡單的增刪改查

進入python manage.py shell

代碼如下:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這兩天在研究閉包,網上一通找,有牛人寫的帖子,有普通人寫的帖子,但是大多沒戳中本小白所糾結的點,而且大多插入了立即執行函數,其實根本不需要的,反而讓人產生了誤解。這裡我用我的方式講解一下閉包。 1.目的:保證局部變數常駐在記憶體中,且只能通過固定的方式訪問,不可以被所有人訪問,算起來也算是個只能被指定 ...
  • 使用匿名自執行函數的作用: (function(window,document,undefined){})(window,document); 1.首先匿名函數 (function(){}) (); 避免函數體內外變數的衝突(js執行表達式順序為圓括弧里到圓括弧外); 2.後面的圓括弧中(windo ...
  • 之前在閱讀《阿裡巴巴Java開發手冊》時,發現有一條是關於迴圈體中字元串拼接的建議,具體內容如下: 那麼我們首先來用例子來看看在迴圈體中用 + 或者用 StringBuilder 進行字元串拼接的效率如何吧(JDK版本為 jdk1.8.0_201)。 可以看出,第 8 行到第 38 行構成了一個迴圈 ...
  • 按照現在流行的互聯網分層架構模型,最簡單的架構當屬Web響應層+DB存儲層的架構。從最開始的單機混合部署Web和DB,到後來將二者拆分到不同物理機以避免共用機器硬體帶來的性能瓶頸,再隨著流量的增長,Web應用變為集群部署模式,而DB則衍生出主從機來保證高可用,同時便於實現讀寫分離。這一連串系統架構的 ...
  • 官網:www.fhadmin.org 特別註意: Springboot 工作流 前後分離 + 跨域 版本 (許可權控制到菜單和按鈕) 後臺框架:springboot2.1.2+ activiti6.0.0+ mybaits+maven+介面 前端頁面:html +vue.js 形式 jquery aj ...
  • django路徑中的"/" 1.django預設會在路徑前加一個"/",因此books前不用加"/"; 2.url:"/books/ajax_delete/"+pk+"/",對於這個路徑,如果books前不加"/",我們在瀏覽器地址欄訪問的時候,會將當前路徑和url進行拼接; 3.url:"/boo ...
  • 2019-10-23-22:58:23 目錄 1.繼承 2.區分成員變數重名的方法 3.區分成員方法重名的方法 4.繼承中重寫與重載的區別 5.繼承中覆蓋重寫的註意事項 6.繼承中覆蓋重寫的設計原則 7.父子類構造方法的特點 8.Super關鍵字的三種使用方法 9.This關鍵字的三種用法 10.S ...
  • 一、可以使用static關鍵字來定義“靜態代碼塊” 1.語法規則 2.靜態代碼塊在類載入時執行,並且只執行一次 3.靜態代碼塊在一個類中可以編寫多個,並且遵循自上而下的順序依次執行。 4.靜態代碼塊的作用是什麼?怎麼使用?用在哪裡?什麼時候用? 這當然和具體的需求有關,例如:項目中要求在類載入的時候 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...