SpringBoot 노트 5 - 데이터베이스를 읽고 쓰는 방법Query 대상을 통해 데이터베이스를 읽고 쓰는 방법
3038 단어 SpringBoot데이터베이스
1 새 UserPersistence 클래스는 다음과 같습니다.
package com.gm.springboot_test.persistence;
import java.util.List;
import com.gm.springboot_test.entity.User;
public interface UserPersistence {
public List getByName(String name);
}
2 새 UserPersistenceImpl 클래스는 다음과 같습니다.
package com.gm.springboot_test.persistence.impl;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;
import org.springframework.stereotype.Repository;
import com.gm.springboot_test.entity.User;
import com.gm.springboot_test.persistence.UserPersistence;
@Repository
public class UserPersistenceImpl implements UserPersistence {
private static final String TABLE_NAME = "user";
@PersistenceContext
private EntityManager em;
@Override
public List getByName(String name) {
// TODO Auto-generated method stub
StringBuilder sqlBuilder = new StringBuilder();
sqlBuilder.append("select id, name, age, sex from " + TABLE_NAME + " where name = ?1");
Map sqlParams = new HashMap();
sqlParams.put(1, name);
Query query = em.createNativeQuery(sqlBuilder.toString());
for (Map.Entry param : sqlParams.entrySet()) {
query.setParameter(param.getKey(), param.getValue());
}
List userList = new ArrayList();
List resultList = query.getResultList();
for (Object obj : resultList) {
Object[] objs = (Object[]) obj;
User user = new User();
user.setId((Integer) objs[0]);
user.setName((String) objs[1]);
user.setAge((Integer) objs[2]);
user.setSex((String) objs[3]);
userList.add(user);
}
return userList;
}
}
3 UserController 클래스를 다음과 같이 수정합니다.
package com.gm.springboot_test.controller;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.gm.springboot_test.entity.User;
import com.gm.springboot_test.persistence.UserPersistence;
@Controller
@RequestMapping("/user")
public class UserController {
@Autowired
private UserPersistence userPersistence;
@RequestMapping("getByName")
@ResponseBody
public String getByName(String name) {
List userList = userPersistence.getByName(name);
String result = "";
for (User user : userList) {
result += user.toString() + "
";
}
return result;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
【Java・SpringBoot・Thymeleaf】 에러 메세지를 구현(SpringBoot 어플리케이션 실천편 3)로그인하여 사용자 목록을 표시하는 응용 프로그램을 만들고, Spring에서의 개발에 대해 공부하겠습니다 🌟 마지막 데이터 바인딩에 계속 바인딩 실패 시 오류 메시지를 구현합니다. 마지막 기사🌟 src/main/res...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.