기본 콘텐츠로 건너뛰기

update MySQL database via python flask

update MySQL database via python flask

제목은 맘대로 지었다.

파이썬 Flask에서 MySQL을 연결하고 DB에 새 정보를 INSERT하는 방법을 알아본다.

파이썬과 Flask를 어느 정도 안다는 가정하에 쓴다.(설명이 좀 불친절한지라...나또한 초보자라 틀린 내용이 있을 수 있음)

1)

이 문서를 찾은 사람들에게 당연히 MySQL DB가 있다는 가정하에,

일단 Flask 패키지가 필요하다.(뭐 이것도 당연히 있겠다만....Flask는 python3 버전에서 다소 불안정하기 때문에 웬만하면 python2.7로 하는 게 좋다.)

pip이나

pip install Flask

PyPI에서 받고

둘 다 안 받아진다 싶으면 구글링을 해서 쉽게 해결할 수 있다.

2)

별로 중요하지 않은 템플릿은 아래 제타위키라는 곳에서 받았다. Bootstrap을 사용했는데 공식홈페이지도 있긴하지만 이 소스가 더 한글에 최적화돼 있는 듯 하다.

기타 소스들은 입맛따라 알아서.

어차피 목표는 플라스크 웹으로 MySQL DB에 접근하는 것이니...

3)

일단 젤 먼저 웹앱을 실행시키는 app.py의 소스는 이렇다.

* 당연히 소스에서 MySQL에 접속하는 HOST나 USER 등은 본인 것으로 해야 한다.

* 버전에 따라 혹 없는 패키지가 있다면 구글링ㄱㄱ 대체재가 꽤 있다.

제일 중요한 부분은 여기. MySQL과 연결하는 부분이다.

cnx = connection.MySQLConnection(user='your_user_name', password='your_password', host='your_host', database='your_database')

어디에서 오류가 나는지 알기 힘들다면 일단 연결만이라도 가능한지부터 확인해보기를 바란다.

4)

아래는 웹에서 쓰일 html 소스다.

코드가 너무 지저분해서 많이 생략했다. 위에서 언급한대로 본인 입맛대로 꾸며보길!

중요한 점은,

* 을 잊지 말 것!

* 텍스트에서 반드시 name 값을 줄 것!

여기다 값을 넣어보쟈

그리고 INSERT 버튼을 누르면 DB에 뿅하고 들어감

들어가는 데 성공하면 /insert_result 경로로 value1값을 시험으로 확인하게 해놨다.

templates 폴더에 insert_result.html 파일하나 만들고

{{value1}} inserted!

넣어주면 끝!

MySQL에 무사히 들어간 데이터!

ㅋㅋㅋㅋ들어갔는지도 불분명한 사진이지만...

회사 계정으로 연습해서 다른 부분을 넣을 수가 없다.

* 다시 말하지만 코드에서 생략한 부분이 많고 본인이 입력해야 하는 부분이 있어서 위 코드를 그대로 적용하면 안 된다.

* Flask는 서버 오류가 많이 나므로 로그를 꼭 찍어주도록 하자.

from http://yuda.dev/59 by ccl(A) rewrite - 2020-03-06 12:20:22

댓글

이 블로그의 인기 게시물

[GCP] Flask로 TF 2.0 MNIST 모델 서빙하기

[GCP] Flask로 TF 2.0 MNIST 모델 서빙하기 Google Cloud Platform 우선 TensorFlow 2.0을 설치하자. 머신에 직접 설치하거나 도커를 다운받아 사용, 혹은 구글 colab을 활용( https://www.tensorflow.org/install)하면 되는데, TensorFlow에서 권장하는대로 머신에 VirtualEnv를 활용해서 설치하자 ( https://www.tensorflow.org/install/pip). 설치하는 김에 Flask도 같이 설치해보자. Compute Machine 하나를 생성(크게 부담 없는 예제라 g1 instance)하고, SSH를 연결하여 실행하면 된다. $ sudo apt update $ sudo apt install python3-dev python3-pip $ sudo pip3 install -U virtualenv # 굳이 system-wide로 flask를 설치할 필요는 없지만 그렇게 했다. $ sudo pip3 install flask $ sudo pip3 install flask-restful # virtualenv 환경에서 tensorflow 2.0 설치 $ virtualenv --system-site-packages -p python3 ./venv $ source ./venv/bin/activate # sh, bash, ksh, or zsh (venv) $ pip install --upgrade pip (venv) $ pip install --upgrade tensorflow 모든 환경이 마련되었으니, 우선 MNIST 모델을 TF 2.0으로 Training하여 모델을 Save 해 두자(tf_mnist_train.py). 대략 99% 이상 정확도가 나온다! import tensorflow as tf import numpy as np # 학습 데이터 load ((train_data, train_label), (eval_data, eval_label)) = tf....

스프링 프레임워크(Spring Framework)란?

스프링 프레임워크(Spring Framework)란? "코드로 배우느 스프링 웹 프로젝트"책을 개인 공부 후 자료를 남기기 위한 목적이기에 내용 상에 오류가 있을 수 있습니다. '스프링 프레임워크'가 무엇인지 말 할 수 있고, 해당 프레임워크의 특징 및 장단점을 설명할 수 잇는 것을 목표로합니다. 1. 프레임워크란? 2. 스프링 프레임워크 "뼈대나 근간을 이루는 코드들의 묶음" Spring(Java의 웹 프레임워크), Django(Python의 웹 프레임워크), Flask(Python의 마이크로 웹 프레임워크), Ruby on rails(Ruby의 웹 프레임워크), .NET Framework, Node.js(Express.js 프레임워크) 등등. 프레임워 워크 종류 : 3. 개발 시간을 단축할 수 있다. 2. 일정한 품질이 보장된 결과물을 얻을 수 있다. 1. 실력이 부족한 개발자라 허다러도 반쯤 완성한 상태에서 필요한 부분을 조립하는 형태의 개발이 가능하다. 프레임워크를 사용하면 크게 다음 3가지의 장점 이 있습니다. 프레임워크 이용 한다는 의미 : 프로그램의 기본 흐름이나 구조를 정하고, 모든 팀원이 이 구조에 자신의 코드를 추가하는 방식으로 개발 한다. => 이러한 상황을 극복하기 위한 코드의 결과물이 '프레임워크' 입니다. 개발자는 각 개개인의 능력차이가 크고, 따라서 개발자 구성에 따라서 프로젝트의 결과 차이가 큽니다. 2. 스프링 프레임워크(Spring Framework) 자바 플랫폼을 위한 오픈 소스 애플리케이션 스프링의 다른 프레임워크와 가장 큰 차이점은 다른 프레임워크들의 포용 입니다. 이는 다시말해 기본 뼈대를 흔들지 않고, 여러 종류의 프레임워크를 혼용해서 사용할 수 있다는 점입니다. 대한민국 공공기관의 웹 서비스 개발 시 사용을 권장하고 있는 전자정부 표준프레임워크 이다. 여러 프레임워크들 중 자바(JAV...

Dummy to resolve the flask problems

Dummy to resolve the flask problems This post is about flask problems that I struggled with. Hope you this is useful things when you taste it. Issue : How to deploy a flask application on Apache2 Resolve : As you know, flask is a micro framework. It can be handled on Apache2 using WSGI module. See the reference. Reference: https://www.digitalocean.com/community/tutorials/how-to-deploy-a-flask-application-on-an-ubuntu-vps Issue : Flask caused ERR_CONNECTION_ABORTED on POST Resolve : There are lots issues for this problem in principle. It caused when browser keep sending some buffer but server doesn't want to receive. My case is like this (submit.html) (submit.py) @bp.route('/submit', methods=["GET", "POST"]) def submit(): return render_template("submit.html") This kinda skel code to explain this. In flask case, this can be caused when it runs as develop server such as run...