[ITWILL : JSP]JDBC활용 - 회원목록출력하는데 관리자는 빼고 출력하기, 자바 에러 두종류

ITWILL학원 : 22강 JSP기초 BY 정규태강사

JDBC

  1. JDBC활용 - import쓰는 이유, form페이지로 받은 데이터를 DB에 insert하는 방법
  2. JDBC활용 - JAVA에서 DB 정보 지우기 2가지방법
  3. JDBC활용 - DB에서 고객정보를 불러와서 HTML테이블에 담기
  4. JDBC활용 - TIMESTAMP주의점, JDBC에서 데이터처리
  5. JDBC활용 - 회원정보수정페이지만들기
  6. JDBC활용 - 회원목록출력하는데 관리자는 빼고 출력하기, 자바 에러 두종류

1. 회원목록출력하는데 관리자는 빼고 출력하기

이는 두가지 방법이 있다.

  1. DB에서 전체 데이터를 불러오고 출력만 관리자빼고하기
  2. DB에서부터 관리자빼고 가져온 뒤 출력하기
  • 어느 방법이 더 좋을까?
    2번째 방법!
    WHY?
    DB에서 데이터를 많이 가져올수록 시간이 오래 걸리므로 2번이 서비스측면에서 효율적이다.

1-1. DB에서 전체 데이터를 불러오고 출력만 관리자빼고하기

조건문으로 한줄이면 끝난다!

if(rs.getString("id").equals("admin")) continue; 짜잔!

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
32
33
34
35
36
37
38
//4. sql구문 & pstmt
String sql = "select * from itwill_member";
PreparedStatement pstmt = con.prepareStatement(sql);

ResultSet rs = pstmt.executeQuery();

//5. 실행 ->rs저장 ->데이터처리
//가져온 최원 정보 모두를 테이블을 사용해서 출력
//관리자는 목록에서 빼기
%>
<table border="1">
<tr>
<td>아이디</td>
<td>비밀번호</td>
<td>이름</td>
<td>나이</td>
<td>성별</td>
<td>이메일</td>
<td>가입일시</td>
</tr>
<%
while(rs.next()){
if(rs.getString("id").equals("admin")) continue;

%>
<tr>
<td><%=rs.getString("id") %></td>
<td><%=rs.getString("pw") %></td>
<td><%=rs.getString("name") %></td>
<td><%=rs.getInt("age") %></td>
<td><%=rs.getString("gender") %></td>
<td><%=rs.getString("email") %></td>
<td><%=rs.getString("reg_date") %></td>
</tr>
<%
}
%>
</table>

1-2. DB에서부터 관리자빼고 가져온 뒤 출력하기

위의 코드에서 if구문을 없애고 sql구문만 변경해주면 된다.

1
String sql = "select * from itwill_member where id not in('admin')";

2. 자바 에러 두종류(JAVA ERROR)

  1. 컴파일에러 = Error
  2. 예외발생 = Exception

[ITWILL : JSP]JDBC활용 - 회원정보수정페이지만들기

ITWILL학원 : 21강 JSP기초 BY 정규태강사

JDBC

  1. JDBC활용 - import쓰는 이유, form페이지로 받은 데이터를 DB에 insert하는 방법
  2. JDBC활용 - JAVA에서 DB 정보 지우기 2가지방법
  3. JDBC활용 - DB에서 고객정보를 불러와서 HTML테이블에 담기
  4. JDBC활용 - TIMESTAMP주의점, JDBC에서 데이터처리
  5. JDBC활용 - 회원정보수정페이지만들기
  6. JDBC활용 - 회원목록출력하는데 관리자는 빼고 출력하기, 자바 에러 두종류

사용자가 로그인한 뒤 자신의 정보를 수정할 수 있는 마이페이지를 만들어보자.

회원정보를 수정할 수 있는 전제는 로그인이다.
로그인이 되어있지않다면 로그인페이지로 이동시켜야한다.
로그인이 되어있는 사용자는 사용자정보를 DB에서 불러와서 화면에 각 요소를 출력한다 -> 원하는 정보를 수정한 뒤 다시 DB에 업데이트해야한다.

1. 회원정보수정폼 페이지만들기

로그인한 사용자에 한하여 DB에 저장되어있는 해당 회원정보를 FORM형식으로 나타내주는 updateForm.jsp 페이지를 만들어보자.

다음은 회원정보수정폼 작성 순서이다.

1-1. 로그인여부를 먼저 체크. & 한글처리 & 변수로딩

  • 로그인이 되어있지않다면 로그인페이지로 이동
  • id값을 가져올 수 있는 방법이 여기서는 두가지이다,
    1. 기본 방식은 파라미터로 가져오거나 = request.getParameter(“id”)
    2. session을 이용했기에 세션활용. 세션값은 object이기에 String으로 형변환필수 = (String) session.getAttribute(“id”)

1-2.드라이브로드 & DB를 연결.

DB에 저장된 회원정보를 사용해야함으로 드라이브로드 & DB를 연결해야한다.

1-3. SQL 구문작성 & pstmt

  • select구문으로 해당 id에 관한 모든 정보를 DB에서 불러온다
  • 많은 컬럼중에 왜 하필 id일까? => id가 primary key이기 때문이다. primary key를 기준으로 where조건문을 걸어 DB에서 데이터를 select하면 된다.
  • select쿼리이므로 executeQuery()와 executeUpdate()중 executeQuery()를 사용하면 된다.
  • select쿼리이므로 pstmt는 int형 변수에 저장해서 사용하면 된다.

1-4. 실행 -> rs에 결과저장 -> 데이터처리

  • 지역변수에 데이터를 넣어서 사용할 수 있다.
  • 지역변수는 멤버변수처럼 자동으로 초기화되지 않는다. 따라서 직접해줘야한다
  • 지역변수의 초기화값은 데이터타입에 따라 다르다. 초기화값은 보통 0이나 null임. 실무에선 String 초기화시 null보단 “”로 사용한다.
데이터타입 초기화값
int 0
String “”(공백)
배열 0
참조형(Timestamp등) null

1-5. 비밀번호를 입력받은 뒤 사용자가 입력한대로 데이터수정하기 -> updatePro.jsp에서 진행

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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<%//1. 로그인여부체크 (로그인x->로그인페이지로이동)
request.setCharacterEncoding("UTF-8");
String id = (String) session.getAttribute("id"); //object이기에 형변환필수

if(id == null){
//로그인페이지이동
response.sendRedirect("loginForm.jsp");
}

//2. 드라이브로드 & 디비연결 : 로그인한 사용자의 정보를 가져오기
final String DRIVER = "com.mysql.jdbc.Driver";
final String DBURL = "jdbc:mysql://localhost:3306/jspdb";
final String DBID = "root";
final String DBPW = "1234";

Class.forName(DRIVER);
Connection con = DriverManager.getConnection(DBURL, DBID, DBPW);
System.out.println("드라이브로드와 디비연결성공");

//3. SQL & PSTMT & 실행
String sql = "select * from itwill_member where id=?";
PreparedStatement pstmt = con.prepareStatement(sql);
pstmt.setString(1, id);

//4. 실행-> rs에 결과저장 -> 데이터처리
ResultSet rs = pstmt.executeQuery();

//지역변수초기화-자동으로 안됨.

String name = "";
int age = 0;
String gender = "";
String email = "";
Timestamp reg_date = null; // Timestamp의 초기값은 null임

if(rs.next()){
//id=rs.getString("id"); 세션으로 가져와서 필요없음
name = rs.getString("name");
age = rs.getInt("age");
gender = rs.getString("gender");
email = rs.getString("email");
reg_date = rs.getTimestamp("reg_date");
}

//4. gender를 입력안하고 회원가입한경우
if(gender == null){
gender="여";
}

//5. 비밀번호를 입력받은 뒤 수정하기 ->updatePro.jsp에서 진행
%>
<fieldset>
<legend>회원정보수정</legend>
<form action="updatePro.jsp" method="post" name="fr">
아이디 <input type="text" name="id" value="<%=id %>" readonly><br>
비밀번호 <input type="password" name="pw"><br>
이름 <input type="text" name="name" value="<%=name %>"><br>
나이 <input type="text" name="age" value="<%=age %>"><br>
성별
<input type="radio" name="gender" value="여"
<% if(gender.equals("여")){ %>
checked
<%}%>
> 여성
<input type="radio" name="gender" value="남"
<% if(gender.equals("남")){ %>
checked
<%}%>
> 남성<br>
이메일 <input type="text" name="email" value="<%=email %>"><br>
<input type="submit" value="회원정보수정하기">
</form>
</fieldset>

2. 회원정보수정페이지의 데이터처리페이지만들기

아래는 회원정보폼에 수정을 하면 update구문을 실행하는 updatePro.jsp 코드이다.

2-1. 로그인여부를 먼저 체크

  • 로그인이 되어있지않다면 로그인페이지로 이동
  • id값을 가져올 수 있는 방법이 여기서는 두가지이다,
    1. 기본 방식은 파라미터로 가져오거나 = request.getParameter(“id”)
    2. session을 이용했기에 세션활용. 세션값은 object이기에 String으로 형변환필수 = (String) session.getAttribute(“id”)

2-2. 한글처리 & 변수가져오기

변수에 전달된 정보를 저장(아이디,비번,이름,나이,성별,이멜)한다

2-3. 드라이브로드 & DB를 연결.

2-4. SQL 구문작성 & pstmt

수정하고자하는 id정보가 DB에 있는지 select구문으로 판단

2-5. 실행 -> rs에 결과저장 -> 데이터처리

  • 아이디,비번 동일한 경우 => 입력받은 데이터를 DB에 update.
  • 비밀번호오류 => 에러메세지
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<%//1.로그인여부체크 ->로그인페이지이동
String id = (String) session.getAttribute("id");
if (id == null) {
response.sendRedirect("loginForm.jsp");
}

//2. 한글처리 & 변수 : 전달된 정보를 저장(아이디,비번,이름,나이,성별,이멜)
request.setCharacterEncoding("UTF-8");
//String id = request.getParameter("id"); 세션으로 이미가져왔음
String pw = request.getParameter("pw");
String name = request.getParameter("name");
int age = Integer.parseInt(request.getParameter("age"));
String email = request.getParameter("email");
String gender = request.getParameter("gender");

//3. 드라이버로드 & DB연결
final String DRIVER = "com.mysql.jdbc.Driver";
final String DBURL = "jdbc:mysql://localhost:3306/jspdb";
final String DBID = "root";
final String DBPW = "1234";

Class.forName(DRIVER);
Connection con = DriverManager.getConnection(DBURL, DBID, DBPW);
System.out.println("updatePro : 드라이브로드와 디비연결성공");

//4. SQL구문 & pstmt실행 & 실행->rs저장
// 4-1 sql구문 : 수정하고자하는 사람의 정보가 있는지 판단 후 select
String sql = "select pw from itwill_member where id=?";
PreparedStatement pstmt = con.prepareStatement(sql);
pstmt.setString(1, id);

//5. 데이터처리
// 아이디,비번 동일한 경우 => 수정
// 비밀번호오류 => 에러메세지

ResultSet rs = pstmt.executeQuery();

if(rs.next()){ //아이디있는 경우
if(pw.equals(rs.getString("pw"))){// 비밀번호 일치하는 경우
sql = "update itwill_member set name=?,age=?,gender=?,email=?"
+"where id=?";
pstmt = con.prepareStatement(sql);
pstmt.setString(1, name);
pstmt.setInt(2, age);
pstmt.setString(3, gender);
pstmt.setString(4, email);
pstmt.setString(5, id);
pstmt.executeUpdate();
System.out.println("회원정보수정완료");
response.sendRedirect("main.jsp");
}else{ // 비밀번호 불일치하는 경우
%>
<script type="text/javascript">
alert("비밀번호오류로 수정불가")
history.back(); //뒤로가기.
</script>
<%
System.out.println("비밀번호오류로 수정불가");
}
}else{ //아이디없는 경우
%>
<script type="text/javascript">
alert("비회원입니다")
history.back(); //뒤로가기.
</script>
<%
System.out.println("아이디오류");
}
%>
여러행함수 : Group by절, Having절

[ITWILL : JSP]JDBC활용 - TIMESTAMP주의점, JDBC에서 데이터처리

ITWILL학원 : 20강 JSP기초 BY 정규태강사

JDBC

  1. JDBC활용 - import쓰는 이유, form페이지로 받은 데이터를 DB에 insert하는 방법
  2. JDBC활용 - JAVA에서 DB 정보 지우기 2가지방법
  3. JDBC활용 - DB에서 고객정보를 불러와서 HTML테이블에 담기
  4. JDBC활용 - TIMESTAMP주의점, JDBC에서 데이터처리
  5. JDBC활용 - 회원정보수정페이지만들기
  6. JDBC활용 - 회원목록출력하는데 관리자는 빼고 출력하기, 자바 에러 두종류

1. MySQL Workbench에서 Timestamp 추가시 주의점

MySQL Workbench에서 row추가시 Timestamp 데이터타입을 쓰고싶다면 TIMESTAMP라고 직접 작성하거나 드롭다운리스트에서 TIMESTAMP()을 찾은 뒤 꼭 괄호를 삭제하고 TIMESTAMP로 apply해야 에러가 발생하지 않는다.

타임스탬프는 사용자가 입력하는 데이터가 아니라 컴퓨터시간에서 가져오는 데이터이다.
따라서 JDBC의 3단계인 sql구문 & DB저장에서 객체생성을 통해 진행할 수 있다.

아래 코드는 JDBC에서 itwill_member테이블에 사용자가 입력한 id, pw와 컴퓨터현재시간을 차례대로 sql구문에 넣는 코드이다.

1
2
3
4
5
6
//3. sql구문 & DB저장 진행시 
String sql = "insert into itwill_member value(?,?,?)";
PreparedStatement pstmt = con.prepareStatement(sql);
pstmt.setString(1, id);
pstmt.setString(2, pw);
pstmt.setTimestamp(3, new Timestamp(System.currentTimeMillis()));

2. JDBC에서 데이터처리

JDBC 3단계인 SQL작성 & pstmt 객체생성 & 데이터처리를 중점으로 로그인페이지를 작성해보자.

  • 아이디 일치 + 비번일치 => 로그인, main페이지이동, id값 세션객체 생성
  • 아이디 일치 + 비번불일치 => 에러(“비밀번호오류”), 뒤로가기
  • 아이디 불일치 => 에러(“비회원입니다”), 뒤로가기
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
32
33
34
35
36
37
38
39
//3-3. 데이터처리
if(rs.next()){ //true라는 건 id가 있다는 소리임 즉, 회원인 경우가 됨
if(pw.equals(rs.getString("pw"))){ //비번일치
//세션ID값생성
session.setAttribute("id", id);
response.sendRedirect("main.jsp"); //js코드보다 java코드가 좋다
System.out.println(id+"로그인성공");
%>
<!-- <script type="text/javascript">
location.href="main.jsp"
</script> js코드보다 java코드가 더 좋다 -->
<%
}else{
System.out.println("비밀번호오류"); //비번불일치
%>
<script type="text/javascript">
alert("비밀번호가 일치하지 않습니다")
//페이지이동 3가지의 차이점
history.back(); //=>작성한 아이디나 데이터가 살아있다
//location.href="loginForm.jsp" //=>작성한 아이디나 데이터가 없다
//location.reload();//=>새로고침으로 alert창이 반복된다
</script>
<%
}
}else{ //false이므로 id가 없다는 소리임. 즉, 비회원인 경우.
System.out.println("아이디오류-비회원입니다");
%>
<script type="text/javascript">
let tmp = confirm("비회원입니다. 회원가입하시겠습니까?")
if(tmp){
location.href="insertForm.jsp";
}else{
history.back();
}

</script>
<%
}
%>

2-1. 페이지이동시 js코드보다 java코드가 좋은 이유

다른 페이지로 이동시 왜 js코드보다 java코드가 더 좋을까?
해당파일의 확장자는 jsp이다. jsp파일이라서 자바코드의 처리가 우선순위에 있다.
js코드인 경우, java로 된 코드가 다 실행되고 난 뒤에 실행이 된다.
이때 이후에 나오는 java코드에 문제가 생기면 js코드가 실행안될 수 있기때문에 아예 java코드를 쓰는것이
실행순서상 좋다.

  1. js코드를 이용한 페이지이동
1
2
3
<script type="text/javascript">
location.href="main.jsp"
</script> -->
  1. java코드를 이용한 페이지이동
1
response.sendRedirect("main.jsp");

2-2. 페이지새로고침 3가지의 차이점.

  • history.back(); : 작성한 아이디나 데이터가 살아있다
  • location.href="loginForm.jsp"; : 작성한 아이디나 데이터가 없다
  • location.reload(); : 새로고침으로 alert창이 반복된다

[ITWILL : JSP]JDBC활용 - DB에서 고객정보를 불러와서 HTML테이블에 담기

ITWILL학원 : 20강 JSP기초 BY 정규태강사

JDBC

  1. JDBC활용 - import쓰는 이유, form페이지로 받은 데이터를 DB에 insert하는 방법
  2. JDBC활용 - JAVA에서 DB 정보 지우기 2가지방법
  3. JDBC활용 - DB에서 고객정보를 불러와서 HTML테이블에 담기
  4. JDBC활용 - TIMESTAMP주의점, JDBC에서 데이터처리
  5. JDBC활용 - 회원정보수정페이지만들기
  6. JDBC활용 - 회원목록출력하는데 관리자는 빼고 출력하기, 자바 에러 두종류

DB저장되어있는 모든 회원정보를 출력하는 코드를 작성해보자.

1. recordset과 resultset

  • recordset = select 구문의 결과. BOF부터 EOF(End Of File)까지의 총 덩어리를 의미.

https://www.xylos.com/en/learning/blog/tip-5-save-time-processing-data-excel-vba-recordset

  • resultset = 테이블을 의미. ex)테이블A, 테이블B, 테이블C 각각이 다 resultset이다.

  • rs.next() = 커서객체를 다음(next)로 넘기는 메서드. row에 데이터가 있으며 true이고 없으면 다음 row로 내려간다. 데이터에 행이 없으면 False가 되고 while문이 종료된다.

  • getString(columnIndex)는 columnIndex안에 테이블의 열번호를 넣으면 된다.

    • 가독성이 떨어지고 모든 열이 어떤 데이터인지 알고있을때 사용할 수있다.
    • 따라서 index값을 사용하는 경우 주석을 적어 무엇을 나타내는 데이터인지 알려주는 것이 좋다.

2. DB에서 고객정보를 불러와서 테이블에 담기.

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
32
<table border="1">
<tr>
<td>인덱스</td>
<td>이름</td>
<td>성별</td>
<td>나이</td>
<td>주민번호</td>
</tr>
<%//1.변수설정
%>
<% //2. 드라이버 로드와 DB연결
final String DRIVER = "com.mysql.jdbc.Driver";
final String DBURL = "jdbc:mysql://localhost:3306/jspdb";
final String DBID = "root";
final String DBPW = "1234";

Class.forName(DRIVER);
Connection con = DriverManager.getConnection(DBURL, DBID, DBPW);

//3.쿼리작성
String sql = "select * from itwill_member";
PreparedStatement pstmt = con.prepareStatement(sql);
ResultSet rs = pstmt.executeQuery();

//3-1.일반출력
/* while(rs.next()){
System.out.println("이름 : " + rs.getString("name") //이름만 출력
+ ", 성별 : " + rs.getString("gender")
+ ", 나이 : " + rs.getInt("age")
+ ", 주민번호 : " + rs.getString("jumin"));
//이름, 나이, 성별, 주민번호 -> 콘솔로 출력하기 -> html 테이블생성해서 출력하기
}*/

2-1. 테이블에 출력

가져온 데이터를 테이블형태로 출력해보는데 2가지 방법이 있다.

  1. 변수지정없이 바로 while반복문실행
    SQL구문작성시 select * from itwill_member이라서 while반복문을 사용했다.
    만약 SQL구문이 select * from itwill_member where id=?로 where조건절을 추가하면 반복문이 아닌 if문으로 사용가능하다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
//3.쿼리작성
String sql = "select * from itwill_member";
PreparedStatement pstmt = con.prepareStatement(sql);

ResultSet rs = pstmt.executeQuery();

while(rs.next()){
%>
<tr>
<td><%=rs.getString(1) %></td> //인덱스
<td><%=rs.getString("name") %></td>
<td><%=rs.getString("gender") %></td>
<td><%=rs.getInt("age") %></td>
<td><%=rs.getString("jumin") %></td>
</tr>
<%
}
%>

</table>
  1. 변수에 저장해서 반복문없이 table에 바로 태그집어넣기
    rs에서 가져온 값을 변수로 저장해서 html table태그에 바로 표현식으로 집어넣을 수 있다.
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
32
33
34
35
36
37
38
39
40
//3.쿼리작성
String sql = "select * from itwill_member where id=?";
PreparedStatement pstmt = con.prepareStatement(sql);
pstmt.setString(1, id);

ResultSet rs = pstmt.executeQuery();

String name = "";
int age = 0;
String gender = "";
String email = "";
Timestamp reg_date = null; //null이 초기값임

if(rs.next()){
//id=rs.getString("id"); 세션으로 가져와서 필요없음
name = rs.getString("name");
age = rs.getInt("age");
gender = rs.getString("gender");
email = rs.getString("email");
reg_date = rs.getTimestamp("reg_date");
}
%>
<table border=1>
<tr>
<td>아이디</td>
<td>이름</td>
<td>나이</td>
<td>성별</td>
<td>이메일</td>
<td>가입일자</td>
</tr>
<tr>
<td><%=id %></td>
<td><%=name %></td>
<td><%=age %></td>
<td><%=gender %></td>
<td><%=email %></td>
<td><%=reg_date %></td>
</tr>
</table>
[패스트캠퍼스python] 장고프로젝만들기 전체 순서/흐름도(ft.쇼핑몰)

[패스트캠퍼스python] 장고프로젝만들기 전체 순서/흐름도(ft.쇼핑몰)

차근차근 순서대로 Django와 python으로 쇼핑몰을 만들어보자.

1. Django 가상환경설정

  1. 가상환경 virtualenv 설치하기 : pip3 install virtualenv
    • 가상환경은 첫 사용시 한번만 설치하면 된다. 이미 설지채놓았다면 2번 가상환경 폴더만들기부터 진행하면된다.
    • virtualenv는 일반적으로 글로벌 설치가 되어야하는 유일한 패키지이다. 나머지 패키지들은 가상 환경에 설치하기때문이다.
Read More