Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 사용자예외클래스생성
- 컬렉션프레임워크
- 오라클
- 정수형타입
- oracle
- 객체 비교
- 생성자오버로드
- 대덕인재개발원
- 다형성
- 메소드오버로딩
- 자동차수리시스템
- 환경설정
- 집합_SET
- abstract
- 컬렉션 타입
- 추상메서드
- Java
- 인터페이스
- NestedFor
- 예외처리
- 제네릭
- exception
- cursor문
- 한국건설관리시스템
- EnhancedFor
- 참조형변수
- GRANT VIEW
- 예외미루기
- 자바
- 어윈 사용법
Archives
- Today
- Total
거니의 velog
231109_Django 과제 1 본문
[HELLO_DJ_MEM.settings]
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'HELLO_DJ_MEM',
]
[HELLO_DJ_MEM.daoMem]
import pymysql # PyMySQL-1.1.0
class DaoMem:
def __init__(self):
print("생성자")
self.conn = pymysql.connect(host='127.0.0.1', port=3305, user='root', password='python', db='python', charset='utf8') # 접속 정보
self.cur = self.conn.cursor(pymysql.cursors.DictCursor)
def selectList(self):
sql = "select * from member"
self.cur.execute(sql)
lists = self.cur.fetchall()
return lists
def selectOne(self, m_id):
sql = f"""
select * from member
where m_id = '{m_id}'
"""
self.cur.execute(sql)
vo = self.cur.fetchone()
return vo
def insert(self, m_id, m_name, tel, email):
sql = f"""
INSERT INTO member (m_id, m_name, tel, email)
VALUES ('{m_id}', '{m_name}', '{tel}', '{email}')
"""
cnt = self.cur.execute(sql)
self.conn.commit()
return cnt
def update(self, m_id, m_name, tel, email):
sql = f"""
UPDATE member SET
m_name = '{m_name}'
, tel = '{tel}'
, email = '{email}'
WHERE m_id = '{m_id}'
"""
cnt = self.cur.execute(sql)
self.conn.commit()
return cnt
def delete(self, m_id):
sql = f"""
DELETE FROM member
WHERE m_id = '{m_id}'
"""
cnt = self.cur.execute(sql)
self.conn.commit()
return cnt
# 소멸자 : destroyer
def __del__(self):
print("소멸자")
self.cur.close()
self.conn.close()
if __name__ == '__main__':
dm = DaoMem()
list = dm.selectList()
print(list)
vo = dm.selectOne('10')
print(vo)
# cnt = dm.insert('10', '10', '1', '10')
# print(cnt)
# cnt = dm.update('10', '이순신', '010-1234-1234', '대전시 서구')
# print(cnt)
# cnt = dm.delete('10')
# print(cnt)
[HELLO_DJ_MEM.views]
from django.http import HttpResponse
from django.shortcuts import render, redirect
from django.views.decorators.csrf import csrf_exempt
import pymysql # PyMySQL-1.1.0
from HELLO_DJ_MEM.daoMem import DaoMem
def mem_list(request):
de = DaoMem()
list = de.selectList()
print(list)
data = {
'list' : list
}
return render(request, "mem_list.html", data)
def mem_detail(request):
m_id = request.GET['m_id']
de = DaoMem()
vo = de.selectOne(m_id)
data = {
'vo' : vo
}
return render(request, "mem_detail.html", data)
def mem_mod(request):
m_id = request.GET['m_id']
de = DaoMem()
vo = de.selectOne(m_id)
data = {
'vo' : vo
}
return render(request, "mem_mod.html", data)
def mem_mod_act(request):
m_id = request.POST['m_id']
m_name = request.POST['m_name']
tel = request.POST['tel']
email = request.POST['email']
de = DaoMem()
modCnt = de.update(m_id, m_name, tel, email)
data = {
'modCnt' : modCnt
}
return render(request, "mem_mod_act.html", data)
def mem_del_act(request):
m_id = request.POST['m_id']
de = DaoMem()
delCnt = de.delete(m_id)
data = {
'delCnt' : delCnt
}
return render(request, "mem_del_act.html", data)
def mem_add(request):
return render(request, "mem_add.html")
def mem_add_act(request):
m_id = request.POST['m_id']
m_name = request.POST['m_name']
tel = request.POST['tel']
email = request.POST['email']
de = DaoMem()
insCnt = de.insert(m_id, m_name, tel, email)
data = {
'insCnt' : insCnt
}
return render(request, "mem_add_act.html", data)
[HELLO_DJ_MEM.urls]
"""
URL configuration for HELLO_DJ_MEM project.
The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/4.2/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: path('', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
from HELLO_DJ_MEM import views
urlpatterns = [
path('', views.mem_list),
path('mem_list', views.mem_list),
path('mem_detail', views.mem_detail),
path('mem_mod', views.mem_mod),
path('mem_mod_act', views.mem_mod_act),
path('mem_del_act', views.mem_del_act),
path('mem_add', views.mem_add),
path('mem_add_act', views.mem_add_act),
]
[mem_list.html]
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>MEM_LIST</title>
<script type="text/javascript">
function fn_add(){
location.href = "mem_add";
}
</script>
</head>
<body>
<h1>MEM_LIST</h1>
<table border="1" style="width: 100%;">
<colgroup>
<col width="25%" />
<col width="25%" />
<col width="25%" />
<col width="25%" />
</colgroup>
<tr>
<th>멤버번호</th>
<th>이름</th>
<th>전화번호</th>
<th>이메일</th>
</tr>
{% for listObj in list %}
<tr>
<td><a href="mem_detail?m_id={{listObj.m_id}}">{{listObj.m_id}}</a></td>
<td>{{listObj.m_name}}</td>
<td>{{listObj.tel}}</td>
<td>{{listObj.email}}</td>
</tr>
{% endfor %}
<tr>
<td colspan="4">
<!-- <a href="emp_add">게시글 등록</a> -->
<button type="button" onclick="fn_add()">멤버 추가</button>
</td>
</tr>
</table>
</body>
</html>
[mem_add.html]
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>MEM_ADD</title>
<script type="text/javascript">
function fn_add_act() {
document.frm_add.submit();
}
</script>
</head>
<body>
<h1>MEM_ADD</h1>
<form name="frm_add" action="mem_add_act" method="post">
{% csrf_token %}
<table border="1" style="width: 100%;">
<colgroup>
<col width="30%" />
<col width="70%" />
</colgroup>
<tr>
<th>멤버번호</th>
<td>
<input type="text" name="m_id" style="width: 95%;" />
</td>
</tr>
<tr>
<th>이름</th>
<td>
<input type="text" name="m_name" style="width: 95%;" />
</td>
</tr>
<tr>
<th>전화번호</th>
<td>
<input type="text" name="tel" style="width: 95%;" />
</td>
</tr>
<tr>
<th>이메일</th>
<td>
<input type="text" name="email" style="width: 95%;" />
</td>
</tr>
<tr>
<td colspan="2">
<button type="button" onclick="fn_add_act()">저장</button>
<a href="mem_list">뒤로가기</a>
</td>
</tr>
</table>
</form>
</body>
</html>
[mem_add_act.html]
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>EMP_ADD_ACT</title>
</head>
<body>
<script type="text/javascript">
var cnt = "{{ insCnt }}";
if(cnt == "1") {
alert("정상적으로 멤버가 등록되었습니다.");
location.href = "mem_list";
}else {
alert("멤버 등록에 실패했습니다.");
history.back();
}
</script>
</body>
</html>
[mem_detail.html]
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>MEM_DETAIL</title>
<script type="text/javascript">
function fn_mod(){
//console.log("fn_mod");
location.href = "mem_mod?m_id={{vo.m_id}}";
}
function fn_del(){
//console.log("fn_mod");
location.href = "mem_del_act?m_id={{vo.m_id}}";
}
function fn_del_act(){
var flag = confirm("한번 지워진 데이터는 복구가 불가합니다.\n정말 삭제하시겠습니까?");
if(!flag){
return;
}
document.frmDel.submit();
}
</script>
</head>
<body>
<h1>MEM_DETAIL</h1>
<table border="1" style="width: 100%;">
<colgroup>
<col width="30%" />
<col width="70%" />
</colgroup>
<tr>
<th>멤버번호</th>
<td>{{ vo.m_id }}</td>
</tr>
<tr>
<th>이름</th>
<td>{{ vo.m_name }}</td>
</tr>
<tr>
<th>전화번호</th>
<td>{{ vo.tel }}</td>
</tr>
<tr>
<th>이메일</th>
<td>{{ vo.email }}</td>
</tr>
<tr>
<td colspan="2">
<a href="mem_mod?m_id={{vo.m_id}}" onclick="fn_mod()">수정</a>
<button type="button" onclick="fn_del_act()">삭제</button>
<a href="mem_list">뒤로가기</a>
</td>
</tr>
<form name="frmDel" action="mem_del_act" method="post">
{% csrf_token %}
<input type="hidden" name="m_id" value="{{vo.m_id}}" />
</form>
</table>
</body>
</html>
[mem_mod.html]
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>MEM_MOD</title>
<script type="text/javascript">
function fn_mod_act() {
document.frm_mod.submit();
}
</script>
</head>
<body>
<h1>MEM_MOD</h1>
<form name="frm_mod" action="mem_mod_act" method="post">
{% csrf_token %}
<table border="1" style="width: 100%;">
<colgroup>
<col width="30%" />
<col width="70%" />
</colgroup>
<tr>
<th>멤버번호</th>
<td>
<input type="text" name="m_id" value="{{ vo.m_id }}" style="width: 95%;" readonly />
</td>
</tr>
<tr>
<th>전화번호</th>
<td>
<input type="text" name="m_name" value="{{ vo.m_name }}" style="width: 95%;" />
</td>
</tr>
<tr>
<th>이메일</th>
<td>
<input type="text" name="tel" value="{{ vo.tel }}" style="width: 95%;" />
</td>
</tr>
<tr>
<th>주소</th>
<td>
<input type="text" name="email" value="{{ vo.email }}" style="width: 95%;" />
</td>
</tr>
<tr>
<td colspan="2">
<button type="button" onclick="fn_mod_act()">저장</button>
<a href="mem_list">뒤로가기</a>
</td>
</tr>
</table>
</form>
</body>
</html>
[mem_mod_act.html]
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>EMP_MOD_ACT</title>
</head>
<body>
<script type="text/javascript">
var cnt = "{{ modCnt }}";
if(cnt == "1") {
alert("정상적으로 수정되었습니다.");
location.href = "mem_list";
}else {
alert("수정에 실패했습니다.");
history.back();
}
</script>
</body>
</html>
[mem_del_act.html]
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>MEM_DEL_ACT</title>
</head>
<body>
<script type="text/javascript">
var cnt = "{{ delCnt }}";
if(cnt == "1") {
alert("정상적으로 삭제되었습니다.");
location.href = "mem_list";
}else {
alert("삭제에 실패했습니다.");
history.back();
}
</script>
</body>
</html>
'대덕인재개발원 > 대덕인재개발원_파이썬 프로그래밍' 카테고리의 다른 글
231113_Django 개론 4 (0) | 2023.11.13 |
---|---|
231110_Django 개론 3 (0) | 2023.11.10 |
231109_Django 개론 2 (0) | 2023.11.09 |
231108_Django 개론 1 (0) | 2023.11.08 |
231107_DB 개론 2 (0) | 2023.11.07 |