Django鏈接使用SQL Server數據庫(windows版)

前言:python

        衆所周知,Django 默認支持sqlite,mysql,oracle,postgresql數據庫,不支持SQL Server數據庫。但實際生產環境中SQL Server數據庫用的仍是比較多的。咱們這裏用ODBC驅動鏈接SQL Server數據庫,進行維護開發。假如你也須要,恭喜你不用再漫天亂扒帖子了。我會盡量的詳細說Django創建和SQL Server數據庫的鏈接方法和存讀已經存在數據的SQL Server數據。mysql

注:另有《Django鏈接使用SQL Server數據庫(linux版)》,請自行在本人博文中查找linux

本人示例環境:

  • 系統版本:Windows2012
  • 數據庫版本:SQL Server2012
  • python版本:Python 3.6.3
  • Django版本:Django2.1
  • 鏈接數據庫工具:Navicat Premium

 

Django鏈接SQL Server前提:

  1. 【服務器屬性--安全性】 開啓SQL Server 和 Windows 身份驗證模式
  2. 【服務器屬性--鏈接】 開啓容許遠程鏈接到此服務器
  3. 創建遠程帳戶能正常遠程訪問和基本的增刪改查權限,第一次測試建議用sa等較高權限,等熟悉了下降用戶權限
  4. 在服務器上安裝Navicat Premium軟件【請自行搜索和安裝】,目的是用ODBC驅動鏈接SQL Server

 

Django鏈接SQL Server步驟:

 

一、安裝必要django環境

pip install django-crontab django-mssql django-pyodbc django-pyodbc-azure django-pytds django-sqlserver

二、數據庫驅動程序檢查

  • 通常第三方鏈接數據庫應用程序都自帶的有,這裏使用 Navicat Premium 示例,軟件安裝略
  • 驅動查看路徑默認爲 C:\Windows\SysWOW64\odbcad32.exe
  • 打開ODBC數據源管理程序,能夠看到全部安裝的ODBC驅動,找到Navicat Client的名稱,用於填寫到Django的setting中做爲指定的默認驅動

 

安裝 Navicat Premium 後去對應目錄查看是否有ODBC驅動sql

 

 

三、Django 的 setting 中配置數據庫鏈接信息

 

須要注意的是 OPTIONS默認數據庫鏈接驅動設置的驅動要和上圖ODBC中驅動保持一致!數據庫

不少人使用mysql多了 端口很容易寫成3306,SQL Server端口默認1433django

DATABASES = {
  'default': {
    'ENGINE': 'sql_server.pyodbc',			        # odbc鏈接固定寫法
    'NAME': 'MySQLserver',				            # 自定義數據庫鏈接名
    'USER': 'sa',					                # 數據庫鏈接帳戶
    'PASSWORD': '123456!@#',				        # 數據庫鏈接密碼
    'HOST': '127.0.0.1',				            # 數據庫服務地址
    'PORT': '1433',					                # 數據庫鏈接端口
    'OPTIONS':{
        'driver':'SQL Server Native Client 11.0',	# ODBC鏈接應用驅動
        'MARS_Connection': True,
    }
  }
}

 

四、Django models表創建

 

注:安全

  1. 由於Django models 使用 python manage.py makemigrations APP python manage.py migrate 生成數據表時表名會自動加上APP的前綴。而若是如今鏈接的數據庫已經有部分數據須要讀取就不得不在 models 的class 中添加 Meta 參數指定數據庫名稱了。
  2. 若是數據庫中已有數據表,字段信息要儘量和數據庫中字段參數保持一致

附:服務器

        使用 python manage.py inspectdb > models.py 命令能夠反向建立和導出數據庫表,但自動建立和導出的表可能會有必定的錯誤和不完整。建議根據自身狀況酌情使用。oracle

        若是你歷來沒有鏈接建立成功過,創建先用models 建立生成一個簡單的表進行測試工具

from django.db import models

class TEST(models.Model):
    ID = models.IntegerField(primary_key=True,)
    NAME = models.CharField(max_length=255,)

    class Meta:						# 若是讀取已有數據的必要參數!
        db_table = "Test_Table"

    def __str__(self):
        return self.NAME

五、附言

        其它地方就和Django普通使用方式是同樣的了~ 鏈接SQL Server 數據庫時候,要想訪問某個表中的某個數據,models.py 中確定是要聲明和指定表名的

        在不少時候鏈接不成功你能夠利用 python manage.py makemigrations APPpython manage.py migrate 來驗證下錯誤信息,若是數據庫中已有該名稱表的數據 僅僅會提示 數據庫中已存在該對象 。當提示該信息時候大部分狀況下你能夠正常的 python manage.py runserver 啓動服務和讀取SQL Server和使用數據庫中的信息了。

        多看看錯誤信息冷靜的思考問題,你會找到答案的。

相關文章
相關標籤/搜索