장고:view 각종 기능: 두 판 사이의 차이
2번째 줄: | 2번째 줄: | ||
==데이터 불러오기== | ==데이터 불러오기== | ||
<br /> | |||
=== 모델의 pk 얻기 === | |||
모델명.id 가 pk이다. | |||
<br /> | |||
===객체 조회=== | ===객체 조회=== | ||
<syntaxhighlight lang="python"> | pk를 알면 다음과 같이 해당 객체를 불러올 수 있다. <code>모델.objects.get(id=pk)</code><syntaxhighlight lang="python"> | ||
from django.shortcuts import get_object_or_404#기본키값에 해당하는 모델이 없을 경우 404 에러 반환. | from django.shortcuts import get_object_or_404#기본키값에 해당하는 모델이 없을 경우 404 에러 반환. | ||
from .models import 모델명#모델을 임포트 한다. | from .models import 모델명#모델을 임포트 한다. | ||
객체 = get_object_or_404(모델명, pk=기본키값) | 객체 = get_object_or_404(모델명, pk=기본키값) | ||
</syntaxhighlight> | </syntaxhighlight><br /> | ||
===목록 조회=== | ===목록 조회=== | ||
<syntaxhighlight lang="python"> | <syntaxhighlight lang="python"> | ||
43번째 줄: | 46번째 줄: | ||
목록2= 목록.objects.filter(조건들..)#객체에 또다시 필터를 걸 수도 있다. | 목록2= 목록.objects.filter(조건들..)#객체에 또다시 필터를 걸 수도 있다. | ||
</syntaxhighlight>필터는 몇번이라도 걸 수 있는데, 장고는 지연평가 방식을 사용하기 때문에 실제로 데이터를 질의하는 것은 한 번 뿐이다. 덕분에 부하가 걸리지 않고도 filter를 자유롭게 사용할 수 있다. | </syntaxhighlight>필터는 몇번이라도 걸 수 있는데, 장고는 지연평가 방식을 사용하기 때문에 실제로 데이터를 질의하는 것은 한 번 뿐이다. 덕분에 부하가 걸리지 않고도 filter를 자유롭게 사용할 수 있다. | ||
=== 특정단어 검색 === | |||
속성에 특정 단어가 포함된 객체를 불러올 땐 다음과 같이 한다. <code>모델.objects.filter(속성__contains='장고')</code> (언더바가 2개임에 유의) | |||
=== 객체의 속성에 접근 === | |||
모델.속성 형태로 속성에 접근 가능하다. 일반적으로 | |||
<code>객체 = 모델.objects.get(id=pk)</code> | |||
객체.속성 형태로 접근한다.(수정을 하고 반드시 저장을 해주어야 한다.) | |||
=== 외래키 연결 === | |||
외래키가 연결된 모델의 경우, 외래키 필드에 해당 키의 아이디(pk)를 넣어주면 된다. | |||
ex) answer(question=질문키, 기타등등 필드 채우기) | |||
이후 answer.save()를 하면 해당 질문에 대한 답변이 저장된다. | |||
answer.question 을 사용하면 어느 질문에 달린 것인지, 질문의 id를 얻어올 수 있다. | |||
=== 질문에서 답변 뽑아내기 === | |||
반대로 질문에서 여러 답변들이 어떤 게 달렸는지 추출할 수도 있다. | |||
모델.연결모델_set.all() 를 실행하면 모델에 연결된 연결모델들 객체를 얻을 수 있다. | |||
==데이터 저장하기== | ==데이터 저장하기== | ||
===객체 저장=== | ===객체 저장=== | ||
객체(모델)를 조회, 조작한 후 모델<code>.save()</code>를 실행한다. | |||
== 데이터 삭제 == | |||
=== 객체 삭제 === | |||
조회, 조작한 후 <code>모델.delete()</code>를 실행. | |||
==권한관리== | ==권한관리== |
2020년 10월 30일 (금) 15:43 판
장고! 웹 프레임워크! 틀:장고
데이터 불러오기
모델의 pk 얻기
모델명.id 가 pk이다.
객체 조회
pk를 알면 다음과 같이 해당 객체를 불러올 수 있다. 모델.objects.get(id=pk)
from django.shortcuts import get_object_or_404#기본키값에 해당하는 모델이 없을 경우 404 에러 반환.
from .models import 모델명#모델을 임포트 한다.
객체 = get_object_or_404(모델명, pk=기본키값)
목록 조회
from django.shortcuts import render
from .models import 모델명#모델을 임포트 한다.
#모델.objects는 객체목록을 받는다는 의미이다.
def index(request):
목록 = 모델.objects.order_by('-create_date') #create_date속성의 역순으로 정리하라는 의미.
context={'템플릿에서 쓸 변수명':목록)
return render(request, '템플릿', context)
객체 다 가져오기
from django.shortcuts import render
from .models import 모델명#모델을 임포트 한다.
#모델.objects는 객체목록을 받는다는 의미이다.
def index(request):
목록 = 모델.objects.all
필터로 걸러서 가져오기
from django.shortcuts import render
from .models import 모델명#모델을 임포트 한다.
#모델.objects는 객체목록을 받는다는 의미이다.
def index(request):
목록 = 모델.objects.filter(칼럼명 = True, >0 따위의 조건들...)
목록2= 목록.objects.filter(조건들..)#객체에 또다시 필터를 걸 수도 있다.
필터는 몇번이라도 걸 수 있는데, 장고는 지연평가 방식을 사용하기 때문에 실제로 데이터를 질의하는 것은 한 번 뿐이다. 덕분에 부하가 걸리지 않고도 filter를 자유롭게 사용할 수 있다.
특정단어 검색
속성에 특정 단어가 포함된 객체를 불러올 땐 다음과 같이 한다. 모델.objects.filter(속성__contains='장고')
(언더바가 2개임에 유의)
객체의 속성에 접근
모델.속성 형태로 속성에 접근 가능하다. 일반적으로
객체 = 모델.objects.get(id=pk)
객체.속성 형태로 접근한다.(수정을 하고 반드시 저장을 해주어야 한다.)
외래키 연결
외래키가 연결된 모델의 경우, 외래키 필드에 해당 키의 아이디(pk)를 넣어주면 된다.
ex) answer(question=질문키, 기타등등 필드 채우기)
이후 answer.save()를 하면 해당 질문에 대한 답변이 저장된다.
answer.question 을 사용하면 어느 질문에 달린 것인지, 질문의 id를 얻어올 수 있다.
질문에서 답변 뽑아내기
반대로 질문에서 여러 답변들이 어떤 게 달렸는지 추출할 수도 있다.
모델.연결모델_set.all() 를 실행하면 모델에 연결된 연결모델들 객체를 얻을 수 있다.
데이터 저장하기
객체 저장
객체(모델)를 조회, 조작한 후 모델.save()
를 실행한다.
데이터 삭제
객체 삭제
조회, 조작한 후 모델.delete()
를 실행.
권한관리
로그인
로그인이 있어야 필요한 기능은 다음과 같은 형태로 구현.(함수 앞에 둔다.)
from django.contrib.auth.decorators import login_required #로그인이 있어야 가능함
@login_required(login_url='common:login')
def question_create(request):
if request.method == 'POST':#포스트로 요청이 들어온다면... 글을 올리는 기능.
form = QuestionForm(request.POST) #폼을 불러와 내용입력을 받는다.
from django.shortcuts import render
from .models import 모델명#모델을 임포트 한다.
#모델.objects는 객체목록을 받는다는 의미이다.
def index(request):
객체 = self.request.user.id #현재 로그인한 사용자의 아이디를 얻을 수 있다.