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

首頁 > 編程 > Python > 正文

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

2020-02-23 01:39:05
字體:
來源:轉載
供稿:網友

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

>>> from django.db import connection>>> cursor = connection.cursor()>>> cursor.execute("""...  SELECT DISTINCT first_name...  FROM people_person...  WHERE last_name = %s""", ['Lennon'])>>> row = cursor.fetchone()>>> print row['John']

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

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

from django.db import connection, modelsclass PersonManager(models.Manager):  def first_names(self, last_name):    cursor = connection.cursor()    cursor.execute("""      SELECT DISTINCT first_name      FROM people_person      WHERE last_name = %s""", [last_name])    return [row[0] for row in cursor.fetchone()]class Person(models.Model):  first_name = models.CharField(max_length=50)  last_name = models.CharField(max_length=50)  objects = PersonManager()

然后這樣使用:

>>> Person.objects.first_names('Lennon')['John', 'Cynthia']

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 嘉义县| 五寨县| 甘肃省| 辽中县| 喀什市| 北辰区| 织金县| 盐池县| 东平县| 洛浦县| 黔南| 太湖县| 海口市| 青川县| 蕲春县| 万安县| 仪征市| 大连市| 隆回县| 景东| 宣化县| 库车县| 娱乐| 东港市| 唐河县| 高邑县| 霸州市| 库尔勒市| 环江| 石楼县| 扬中市| 若尔盖县| 巴彦淖尔市| 卢龙县| 武威市| 武穴市| 亚东县| 淳安县| 偏关县| 罗江县| 社会|