본문 바로가기

프로그래밍/JSP

[JSP]JDBC insert 예제

1. 페이지 부분

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	<form action="insertPro.jsp" method="post">
		아이디   : <input type="text" name="id"><br>
		비밀번호 : <input type="password" name="pw"><br>
		이메일   : <input type="text" name="email"><br>
		<input type="submit" value="가입하기">
	</form>
</body>
</html>

 

2. 처리 부분

<%@page import="java.sql.PreparedStatement"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.Connection"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>

	<%
		//이전 페이지에서 전달된 데이터 저장 -> 콘솔 출력
        
		// post 경우 한글이 깨져서 설정
		request.setCharacterEncoding("UTF-8");
		
		String id = request.getParameter("id");
		String pw = request.getParameter("pw");
		String email = request.getParameter("email");
	
		//DB에 저장
		final String DRIVER = "com.mysql.jdbc.Driver";
		final String DBURL = "jdbc:mysql://localhost:3306/jspdb";
		final String DBID = "root";
	 	final String DBPW = "1234";
	 	
		// 1단계 드라이버 로드
		Class.forName(DRIVER);
		
		// 2단계 디비 연결
		Connection conn = DriverManager.getConnection(DBURL, DBID, DBPW);

		// 3단계 sql 구문 작성 & statement 객체 생성 (-> preparedstatement 변경 예정)
		String sql = "insert into itwill_member (id, pw, email) values(?, ?, ?)";

		// Statement : SQL 구문을 실행하는 객체
		// PreparedStatement : SQL 구문을 실행하는 객체
		// -> 쿼리문을 실행할 준비가 되어있는 상태(처리속도  우수, 보안상 안전)
		
		// Statement stmt = conn.createStatement(); 
		PreparedStatement pstmt = conn.prepareStatement(sql);
		
		// ? 채우기
		// XXXXX는 컬럼의 데이터 타입에 따라서 변경
		// pstmt.setXXXXXX(?의 위치, 저장할 값);
		pstmt.setString(1, id);
		pstmt.setString(2, pw);
		pstmt.setString(3, email);

		// 4단계 SQL 구문을 실행
		// stmt.executeUpdate(sql);
		
		// pstmt.executeUpdate();
		// => insert, update, delete 구문을 쓸 때 사용
				
		// pstmt.executeQuery();
		// => select 구문을 쓸 때 사용
		
		pstmt.executeUpdate();
	%>
</body>
</html>

'프로그래밍 > JSP' 카테고리의 다른 글

[JSP]JDBC update 예제  (0) 2021.04.09
[JSP]JDBC delete 예제  (0) 2021.04.09
[JSP]JDBC (자바 & MySQL데이터베이스 연동)  (0) 2021.04.08
[JSP]쿠키와 세션  (0) 2021.04.01
[JSP]영역객체와 속성  (0) 2021.03.30