TigerCow.Door

'django 시작'에 해당되는 글 2건


안녕하세요. 문범우입니다.

이번 포스팅에서는 django에서 postgreSQL을 사용하는 방법에 대해서 알아보도록 하겠습니다.

현재 진행되는 환경은 django 2.0 / OS X / python 3.6.4 입니다.


1. postgreSQL 설정


postgreSQL은 관계형데이터베이스 중 하나로써, 먼저 이를 사용하기 위해 설치를 필요로 합니다.


postgreSQL 설치방법은 아래 글에 나와있으니 참고하시길 바랍니다.


http://doorbw.tistory.com/179?category=711158


postgreSQL 설치가 완료되었으면 터미널로 아무 데이터베이스나 접속합니다.

그리고 django에서 사용할 데이터베이스를 새로 만들어보도록 하겠습니다.


create database django_test;


를 입력합니다.



그리고 새롭게 만든 데이터베이스로 들어갑니다.


새롭게 만든, django_test 데이터베이스로 들어왔으면, 새로운 유저를 만들고 몇가지 설정과 함께 권한을 부여합니다.

순서대로 아래의 명령어를 입력합니다.


create user root with password 'password';

root는 유저 이름이고, password는 비밀번호입니다. 이때 비밀번호는 따옴표로 감싸주어야 합니다.

alter role root set client_encoding to 'utf-8';

alter role root set timezone to 'Asia/Seoul';

grant all privileges on database django_test to root;



위와 같이 하면 데이터베이스에 대한 설정이 마무리됩니다.



2. django 설정


먼저, django 설정을 진행하기 전에 필요한 것을 설치해야 됩니다.


psycopg2 라는 것을 설치해야 되는데, 터미널창에서 pip로 설치를 진행합니다.


pip install --no-binary :all: psycopg2




이렇게 설치가 마무리 되었으면, 이제 postgreSQL을 적용할 django 프로젝트로 들어가서 settings.py 파일을 열어봅니다.


그리고 그 중 아래와 같이 installed_apps 항목을 찾아서 우리가 만든 app을 추가합니다.




그리고 아래와 같이 database항목을 찾아봅니다.




위의 DATABASES 항목을 아래와 같이 수정합니다.


1
2
3
4
5
6
7
8
9
10
DATABASES = {
    'default': {
        'ENGINE''django.db.backends.postgresql',
        'NAME''django_test',
        'USER''root',
        'PASSWORD''password',
        'HOST''localhost',
        'PORT''',
    }
}
cs


name은 database의 이름을

user는 user의 이름,

password에는 user의 비밀번호를 입력합니다.


그리고 blog라고 새롭게 만든 app의 models.py 파일을 열어서 아래와 같이 작성합니다.


1
2
3
4
5
6
7
from django.db import models
 
# Create your models here.
class Post(models.Model):
    name = models.CharField(max_length = 20)
    content = models.TextField()
 
cs


이것은 우리가 blog라는 앱에서 데이터베이스 내부에 Post라는 table을 만드는 것이라고 생각하시면 됩니다.

일단은 간단하게 name과 content만을 갖도록 하였고, id같은 경우는 자동적으로 만들어지게 됩니다.


이렇게 까지 하고 django 프로젝트 폴더로 들어가서 아래와 같은 명령어를 입력해 줍니다.


python manage.py makemigrations


python manage.py migrate


이렇게 하고 


python manage.py runserver


를 통해 서버가 정상적으로 돌아가는지 확인합니다.


이제 다시 postgresql로 돌아와 우리가 만든 테이블이 잘 있는지 확인해보겠습니다.

실제로 django project내에서 따로 admin 페이지를 통해 확인할 수도 있지만, admin과 관련된 것은 다음포스팅에서 다뤄보도록 하겠습니다.


postgresql 터미널로 들어와서 아래 명령어를 입력하여 테이블 리스트를 확인합니다


\dt 



다양한 테이블이 많은데, 그중 가운데쯤 잘 보시면 blog_post 라는 테이블이 있습니다.

해당 테이블이 우리가 위에서 django 프로젝트를 통해서 만들게된 테이블입니다.



이렇게 하여 django 프로젝트에서 데이터베이스를 postgresql 로 연결하는 방법을 알아보았습니다.

다음 포스팅에서는 admin을 사용해보면서 실제로 데이터베이스에 데이터를 입력하고 확인해보도록 하겠습니다.

블로그 이미지

Tigercow.Door

Web Programming / Back-end / Database / AI / Algorithm / DeepLearning / etc


안녕하세요. 문범우입니다.

이번 포스팅에서는 django에서 첫화면을 만들어보도록 하겠습니다.

먼저 우리가 만들어볼 전체적인 그림은 MVC패턴을 이용하여 간단한 블로그를 만들어 보는 것 입니다.

글을 작성하고 이것이 데이터베이스에 저장되고, 글을 삭제하거나 그에 대한 댓글을 다는 등의 기능을 구현해보도록 할 것 입니다.

먼저 이번 포스팅에서는 위에서 말씀드린 것과 같이 간단하게 첫화면을 만들어보도록 하겠습니다.


1. App 만들기


먼저 우리는 지난 포스팅을 통해서 start_django라는 프로젝트를 만들었습니다.

장고에서는 프로젝트 내부에 여러개의 app이 존재하면서 여러개의 기능을 구현할 수 있습니다.


먼저 우리는 blog라는 app을 만들어 보도록 하겠습니다.


터미널(윈도우의 경우 cmd창)을 열어서 지난 포스트에서 만든 프로젝트까지 이동합니다.

그리고 아래의 명령어를 입력합니다.


python manage.py startapp blog



그럼 위와 같이 start_django라는 우리의 프로젝트 폴더안에 blog라는 폴더가 새로 생긴 것을 확인할 수 있습니다.

현재 명령어 창이 위치한 start_django 폴더는 프로젝트의 기본 폴더라고 생각하시면 되고, 이 내부에 blog라는 app이 존재하며, 또 존재하는 start_django 폴더는 프로젝트 전체에 대한 설정 파일들이 담겨 있다고 생각하시면 됩니다.



2. 첫번째 화면 만들기


그럼 첫번째화면을 만들기 위해서 먼저 url지정을 진행해보도록 하겠습니다.

에디터를 통해 start_django > start_django > urls.py 파일을 열어봅니다.



위와 같이 매우 긴 주석처리와 약간의 코드가 존재합니다.

django 1.x 버전과 2.0 버전의 차이점 중의 하나가 여기서 나타나는데, 1.x 버전에서는 url 지정에서 url 함수를 사용하며 정규식을 사용하는데 2.0 이후부터는 path함수를 통해 정규식이 필요 없어지게 되었습니다.


우리가 추가하고자 하는 url은 맨처음 들어올 메인화면에 대한 것이므로 다음과 같이 코드를 수정합니다. (주석처리된 곳은 삭제하여도 무방합니다.)


1
2
3
4
5
6
7
from django.contrib import admin
from django.urls import path, include
 
urlpatterns = [
    path('', include('blog.urls')),
    path('admin/', admin.site.urls),
]
cs


2번째 줄을 보시면 include라는 함수를 추가로 import 하였습니다.

그리고 5번줄에서 path함수를 활용하여 첫 화면, 아무것도 입력되지 않은 url에서는 blog의 urls를 참고하도록 하였습니다.


이제 blog라는 폴더안에 urls.py 이라는 파일을 새로 만들어서 아래와 같이 코드를 작성합니다.


1
2
3
4
5
6
from django.urls import path
from . import views
 
urlpatterns = [
    path('', views.index),
]
cs


해당 urls.py 파일은 위에서 작성한 파일과 다른 파일입니다.

blog라는 폴더 내부에 새롭게 만든 파일입니다.

먼저 해당 blog에서는 존재하지 않은 admin관련 import를 삭제하였습니다.

admin과 관련되어서는 추후 model을 다루게 될때 살펴보도록 하겠습니다.

그리고 화면을 보여주도록 할 views 파일을 import 하였고, url패턴에서 아무것도 입력되지 않은 주소에 대해서 views의 index를 참고하도록 하였습니다.


그럼 마지막으로 blog 폴더에 있는 views.py 파일을 열어 아래와 같이 코드를 작성합니다.


1
2
3
4
5
6
from django.shortcuts import render
from django.http import HttpResponse
 
# Create your views here.
def index(request):
    return HttpResponse("Main Screen!!!")
cs


2번째 줄에, HttpResponse 라는 함수를 추가로 import하였습니다.

그리고 index라는 함수를 만들었고 단순히 HttpResponse함수를 통한 반환을 하도록 하였습니다.


이렇게 하고 명령어창을 기본 start_django 폴더에 위치하게 한다음, 아래의 명령어를 입력하면 서버가 돌아가게 됩니다.


python manage.py runserver



migrations 에 대한 경고가 뜨는데 일단은 무시하겠습니다.

그리고 이제 localhost:8000 으로 접속하게 되면 아래와 같이 우리가 작성한 첫화면이 나오게 됩니다.



블로그 이미지

Tigercow.Door

Web Programming / Back-end / Database / AI / Algorithm / DeepLearning / etc