国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

在Django的模型中執行原始SQL查詢的方法

2020-01-04 18:00:57
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了在Django的模型中執行原始SQL查詢的方法,Django是最具人氣的Python web開發框架,需要的朋友可以參考下

有時候你會發現Django數據庫API帶給你的也只有這么多,那你可以為你的數據庫寫一些自定義SQL查詢。 你可以通過導入django.db.connection對像來輕松實現,它代表當前數據庫連接。 要使用它,需要通過connection.cursor()得到一個游標對像。 然后,使用cursor.execute(sql, [params])來執行SQL語句,使用cursor.fetchone()或者cursor.fetchall()來返回記錄集。 例如:

 

 
  1. >>> from django.db import connection 
  2. >>> cursor = connection.cursor() 
  3. >>> cursor.execute(""
  4. ... SELECT DISTINCT first_name 
  5. ... FROM people_person 
  6. ... WHERE last_name = %s""", ['Lennon']) 
  7. >>> row = cursor.fetchone() 
  8. >>> print row 
  9. ['John'

connection和cursor幾乎實現了標準Python DB-API,你可以訪問` http://www.python.org/peps/pep-0249.html `__來獲取更多信息。 如果你對Python DB-API不熟悉,請注意在cursor.execute() 的SQL語句中使用`` “%s”`` ,而不要在SQL內直接添加參數。 如果你使用這項技術,數據庫基礎庫將會自動添加引號,同時在必要的情況下轉意你的參數。

不要把你的視圖代碼和django.db.connection語句混雜在一起,把它們放在自定義模型或者自定義manager方法中是個不錯的主意。 比如,上面的例子可以被整合成一個自定義manager方法,就像這樣:

 

 
  1. from django.db import connection, models 
  2.  
  3. class PersonManager(models.Manager): 
  4. def first_names(self, last_name): 
  5. cursor = connection.cursor() 
  6. cursor.execute(""
  7. SELECT DISTINCT first_name 
  8. FROM people_person 
  9. WHERE last_name = %s""", [last_name]) 
  10. return [row[0] for row in cursor.fetchone()] 
  11.  
  12. class Person(models.Model): 
  13. first_name = models.CharField(max_length=50) 
  14. last_name = models.CharField(max_length=50) 
  15. objects = PersonManager() 

然后這樣使用:

 

 
  1. >>> Person.objects.first_names('Lennon'
  2. ['John''Cynthia'
 

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沈阳市| 随州市| 恭城| 海城市| 翁源县| 奉贤区| 读书| 靖西县| 壶关县| 武定县| 锡林郭勒盟| 喀什市| 杭锦旗| 南岸区| 侯马市| 广昌县| 建湖县| 阿拉尔市| 东海县| 红河县| 浠水县| 平谷区| 阿坝县| 桦南县| 玉树县| 五大连池市| 宿松县| 嫩江县| 迁西县| 枣强县| 正蓝旗| 龙胜| 隆子县| 德江县| 枞阳县| 威信县| 南安市| 瓮安县| 嘉义县| 上高县| 巴东县|