亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > django執行原生SQL查詢的實現

django執行原生SQL查詢的實現

熱門標簽:西青語音電銷機器人哪家好 成都呼叫中心外呼系統哪家強 旅游廁所地圖標注怎么弄 百應電話機器人總部 地圖標注與注銷 宿州電話機器人哪家好 無錫智能外呼系統好用嗎 南昌地圖標注 電梯新時達系統外呼顯示e

執行原生 SQL 查詢

Django 允許你用兩種方式執行原生 SQL 查詢:

  • 你可以使用 Manager.raw() 來 執行原生查詢并返回模型實例。
  • 或者完全不用模型層 直接執行自定義 SQL。

1、執行原生查詢

管理器方法 raw() 能用于執行原生 SQL 查詢,就會返回模型實例:

Manager.raw(raw_query, params=None, translations=None)

該方法接受一個原生 SQL 查詢語句,執行它,并返回一個 django.db.models.query.RawQuerySet 實例。這個 RawQuerySet 能像普通的 QuerySet 一樣被迭代獲取對象實例。

1.1 普通查詢

class Person(models.Model):
    first_name = models.CharField(...)
    last_name = models.CharField(...)
    birth_date = models.DateField(...)

然后你可以像這樣執行自定義 SQL:

for p in Person.objects.raw('SELECT * FROM app_person'): # django默認的表名是app名加類名
    print(p)
​# 沒有查詢到就報錯

1.2 將查詢字段映射為模型字段

raw() 字段將查詢語句中的字段映射至模型中的字段。
查詢語句中的字段排序并不重要。換而言之,以下兩種查詢是一致的:

Person.objects.raw('SELECT id, first_name, last_name, birth_date FROM app_person')

Person.objects.raw('SELECT last_name, birth_date, first_name, id FROM app_person')

匹配是根據名字來的。這意味著你可以使用 SQL 的 AS 子句將查詢語句中的字段映射至模型中的字段。所以,若你還有一些數據表包含了 Person 數據,你可以很方便的將其映射至 Person 實例:

>>> Person.objects.raw('''SELECT first AS first_name,
...                              last AS last_name,
...                              bd AS birth_date,
...                              pk AS id,
...                       FROM app_person''')

只要名字對上了,模型實例就會被正確創建。

或者,你可以用 raw() 的 translations 參數將查詢語句中的字段映射至模型中的字段。這是一個字典,將查詢語句中的字段名映射至模型中的字段名。例如,上面的查詢也能這樣寫:

>>> name_map = {'first': 'first_name', 'last': 'last_name', 'bd': 'birth_date', 'pk': 'id'}
>>> Person.objects.raw('SELECT * FROM some_other_table', translations=name_map)

1.3 索引查詢

raw() 支持索引,所以,若你只需要第一個結果就這樣寫:

>>> first_person = Person.objects.raw('SELECT * FROM app_person')[0]

1.4 將參數傳給 raw()

如果你需要執行參數化的查詢,可以使用 raw() 的 params 參數:

>>> lname = 'Doe'
>>> Person.objects.raw('SELECT * FROM myapp_person WHERE last_name = %s', [lname])

params 是一個參數字典。你將用一個列表替換查詢字符串中 %s 占位符,或用字典替換 %(key)s 占位符(其中, key 理所應當由字典 key 替換),不論你使用哪個數據庫引擎。這些占位符會被 params 參數的值替換。
!!!必須以列表形式傳入參數,格式一定是這樣寫,不能寫成字符串

2、直接執行自定義 SQL

繞過模型層。

對象 django.db.connection 代表默認數據庫連接。要使用這個數據庫連接,調用 connection.cursor() 來獲取一個指針對象。然后,調用 cursor.execute(sql, [params]) 來執行該 SQL 和 cursor.fetchone(),或 cursor.fetchall() 獲取結果數據。

from django.db import connection
​
def my_sql(self):
    with connection.cursor() as cursor:
        cursor.execute("UPDATE bar SET foo = 1 WHERE baz = %s", [self.baz])
        cursor.execute("SELECT foo FROM bar WHERE baz = %s", [self.baz])
        row = cursor.fetchone()
​
    return row

要避免 SQL 注入,你絕對不能在 SQL 字符串中用引號包裹 %s 占位符。
注意,若要在查詢中包含文本的百分號,你需要在傳入參數使用兩個百分號:

cursor.execute("SELECT foo FROM bar WHERE baz = '30%%' AND id = %s", [self.id])

2.1 指定連接數據庫

用 django.db.connections 獲取指定數據庫的連接(和指針)。 django.db.connections 是一個類字典對象,它允許你通過連接別名獲取指定連接:

from django.db import connections
with connections['my_db_alias'].cursor() as cursor:

 到此這篇關于django執行原生SQL查詢的實現的文章就介紹到這了,更多相關django執行原生SQL查詢內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • django執行原始查詢sql,并返回Dict字典例子
  • 在Django的模型中執行原始SQL查詢的方法

標簽:辛集 渭南 七臺河 雅安 濰坊 西安 贛州 許昌

巨人網絡通訊聲明:本文標題《django執行原生SQL查詢的實現》,本文關鍵詞  django,執行,原生,SQL,查詢,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《django執行原生SQL查詢的實現》相關的同類信息!
  • 本頁收集關于django執行原生SQL查詢的實現的相關信息資訊供網民參考!
  • 推薦文章
    一级毛片视频在线观看| 99色视频在线观看| 国产伦精品一区二区三区无广告| 精品国产亚洲人成在线| 免费一级片在线观看| 高清一级片| 成人免费网站视频ww| 亚洲爆爽| 午夜激情视频在线播放| 久久成人综合网| 国产伦精品一区二区三区无广告| 午夜激情视频在线播放| 天天色色色| 欧美另类videosbestsex高清| 欧美a级成人淫片免费看| 国产精品1024永久免费视频| 麻豆网站在线免费观看| 精品视频一区二区三区| 亚洲第一色在线| 日日夜夜婷婷| 日本特黄特色aaa大片免费| 日本在线www| 日本在线不卡免费视频一区| 韩国妈妈的朋友在线播放| 日本特黄特色aaa大片免费| 日韩在线观看视频网站| 精品国产三级a∨在线观看| 韩国妈妈的朋友在线播放| 91麻豆高清国产在线播放| 国产伦精品一区二区三区无广告| 欧美a级成人淫片免费看| 欧美日本韩国| 黄色福利片| 精品久久久久久中文字幕一区| 午夜在线亚洲| 国产原创中文字幕| 精品国产一区二区三区免费| 国产精品自拍在线| 精品久久久久久中文字幕一区| 国产91精品露脸国语对白| 国产一级强片在线观看| 日韩男人天堂| 国产成人精品影视| 日韩字幕在线| 国产不卡福利| 久久久成人影院| 欧美国产日韩久久久| 一级女性全黄生活片免费| 国产亚洲精品aaa大片| 精品国产三级a∨在线观看| 91麻豆高清国产在线播放| 亚洲 国产精品 日韩| 国产一区二区精品久| 在线观看导航| 色综合久久天天综线观看| 国产网站免费观看| 91麻豆精品国产自产在线| 精品在线免费播放| 四虎影视久久久| 四虎久久影院| 国产91素人搭讪系列天堂| 可以在线看黄的网站| 国产麻豆精品hdvideoss| 四虎久久影院| 美女免费精品视频在线观看| 久久精品道一区二区三区| 一级女性大黄生活片免费| 麻豆系列 在线视频| 黄视频网站在线看| 99久久精品国产片| 日韩一级精品视频在线观看| 色综合久久手机在线| 国产精品123| 国产成人啪精品| 可以免费看污视频的网站| 精品国产香蕉在线播出| 日韩中文字幕一区| 欧美激情一区二区三区中文字幕| 精品国产亚洲人成在线| 国产伦久视频免费观看视频| 日韩一级黄色| 亚欧视频在线| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 欧美激情在线精品video| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩在线观看视频网站| 日本特黄一级| 四虎影视库国产精品一区| 欧美另类videosbestsex高清| 国产不卡在线播放| 日本特黄特色aaa大片免费| 欧美另类videosbestsex视频| 国产一区二区福利久久| 国产一区二区精品| 精品久久久久久影院免费| 国产不卡精品一区二区三区| 国产不卡福利| 国产亚洲免费观看| 精品久久久久久影院免费| 精品国产三级a∨在线观看| 久久国产精品自由自在| 国产精品1024永久免费视频| 国产a视频| 日韩在线观看视频黄| 日韩在线观看视频网站| 国产一区二区福利久久| 欧美激情在线精品video| 国产伦精品一区三区视频| 欧美激情在线精品video| 日韩欧美一二三区| 亚洲 国产精品 日韩| 夜夜操天天爽| 黄视频网站在线免费观看| 午夜精品国产自在现线拍| 日韩一级黄色| a级毛片免费观看网站| 日韩欧美一二三区| 99热精品一区| 精品久久久久久影院免费| 高清一级片| 国产视频一区在线| 91麻豆精品国产高清在线| 麻豆网站在线免费观看| 精品视频一区二区三区| 色综合久久手机在线| 国产一区免费观看| 成人免费高清视频| 一级女性大黄生活片免费| 午夜激情视频在线播放| 麻豆网站在线免费观看| 成人在免费观看视频国产| 精品国产三级a∨在线观看| 国产成人啪精品| 国产91精品露脸国语对白| 成人影视在线观看| 日韩一级精品视频在线观看| 国产亚洲免费观看| 久久成人综合网| 欧美a级片视频| 天天做日日爱| 美女免费黄网站| 91麻豆精品国产高清在线| 欧美1卡一卡二卡三新区| 免费毛片播放| 久草免费资源| 成人免费观看网欧美片| 国产一区二区精品尤物| 国产视频网站在线观看| 97视频免费在线| 久久国产精品只做精品| 一级毛片视频在线观看| 色综合久久天天综线观看| 亚洲天堂免费观看| 韩国三级视频网站| 精品国产一区二区三区国产馆| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产精品123| 久久精品人人做人人爽97| 国产91精品一区| 国产美女在线观看| 久久国产一区二区| 沈樵在线观看福利| 日本免费区| 色综合久久天天综合观看| 精品在线免费播放| 精品国产一区二区三区免费| 久久国产精品自由自在| 999精品在线| 免费国产一级特黄aa大片在线| 国产一级强片在线观看| 成人a大片高清在线观看| 麻豆系列 在线视频| 日日日夜夜操| 韩国三级视频在线观看| 沈樵在线观看福利| 九九久久国产精品| 天天色色色| 成人影视在线观看| 麻豆网站在线免费观看| 九九免费精品视频| 韩国三级视频在线观看| 91麻豆国产级在线| 九九久久99| 99久久精品国产片| 麻豆网站在线免费观看| 日韩在线观看免费| 欧美a免费| 成人免费观看网欧美片| 亚洲精品中文一区不卡| 黄视频网站在线看| 精品国产香蕉在线播出| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 日韩一级黄色| 国产一区二区精品尤物| 亚久久伊人精品青青草原2020| 亚洲 男人 天堂| 亚洲爆爽| 色综合久久天天综线观看| 欧美a级成人淫片免费看| 久久精品道一区二区三区|