django中使用原生sql语句的方法步骤

raw

# row方法:(掺杂着原生sql和orm来执行的操作)
res = CookBook.objects.raw(\'select id as nid from epos_cookbook where id>%s\', params=[1, ])
print(res.columns) # [\'nid\']
print(type(res)) # <class \'django.db.models.query.RawQuerySet\'>

# 在select里面查询到的数据orm里面的要一一对应
res = CookBook.objects.raw(\"select * from epos_cookbook\")
print(res)
for i in res:
  print(i.create_date)
  print(i)
  
res = CookBook.objects.raw(\'select * from epos_cookbook where id>%s\', params=[1, ])
# 后面可以加参数进来
print(res)
for i in res:
  # print(i.create_date)
  print(i)

extra

## select提供简单数据
# SELECT age, (age > 18) as is_adult FROM myapp_person;
Person.objects.all().extra(select={\'is_adult\': \"age > 18\"}) # 加在select后面

## where提供查询条件
# SELECT * FROM myapp_person WHERE first||last ILIKE \'jeffrey%\';
Person.objects.all().extra(where=[\"first||last ILIKE \'jeffrey%\'\"]) # 加一个where条件

## table连接其它表
# SELECT * FROM myapp_book, myapp_person WHERE last = author_last
Book.objects.all().extra(table=[\'myapp_person\'], where=[\'last = author_last\']) # 加from后面

## params添参数
# !! 错误的方式 !!
first_name = \'Joe\' # 如果first_name中有SQL特定字符就会出现漏洞
Person.objects.all().extra(where=[\"first = \'%s\'\" % first_name])
# 正确方式
Person.objects.all().extra(where=[\"first = \'%s\'\"], params=[first_name])

connection(类似pymysql)

from django.db import connection

 cursor=connection.cursor()
 # 如果需要配置数据库
 # cursor=connection[\'default\'].cursor() 
 
 cursor.execute(\'select * from app01_book\')

 ret=cursor.fetchall()

 print(ret)
 #((2, \'小时光\', Decimal(\'10.00\'), 2), (3, \'未来可期\', Decimal(\'33.00\'), 1), (4, \'打破思维里的墙\', Decimal(\'11.00\'), 2), (5, \'时光不散\', Decimal(\'11.00\'), 3))

注意:如果在sql语句中有用到除法(%),需要使用%%来转义,因为在str中%多用于格式化输出。

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容