๋ชฉ์ฐจ
ํด๋น ํ๋ก์ ํธ๋ ์ฃผ๋ฌธ์ ์ ์์๊ณต์ธ๋ค์ ์ํ ์ฃผ๋ฌธ ํ๋ซํผ ํ๋ก์ ํธ์ ๋๋ค.
ํ๋ก์ ํธ์ ๋ํ ์์ธํ ๋ด์ฉ์ ๊นํ๋ธ๋ฅผ ์ฐธ๊ณ ํด์ฃผ์ธ์ :)
https://github.com/hyejux/Neez
GitHub - hyejux/Neez: ์์ฝ ์ด์ ๋ ํธ๋ฆฌํ๊ฒ, ๊ด๋ฆฌ๋ ์์ฝ๊ฒ NEEZ ์์ ๊ฒฝํํด๋ณด์ธ์! ใ์ฃผ๋ฌธ ์ ์ ์
์์ฝ ์ด์ ๋ ํธ๋ฆฌํ๊ฒ, ๊ด๋ฆฌ๋ ์์ฝ๊ฒ NEEZ ์์ ๊ฒฝํํด๋ณด์ธ์! ใ์ฃผ๋ฌธ ์ ์ ์์ฝ ์๋น์ค "NEEZ "ใ - hyejux/Neez
github.com
ํด๋น ๊ฒ์๋ฌผ์ ๊ธฐ๋ฅ ๊ตฌํ์ ๋ํ ๋ด์ฉ์ ์ ๋ฆฌํด๋์์ต๋๋ค.
1) ํ์ด์ง ๋์์ธ ๊ตฌ์
[๊ด๋ฆฌ์ ํ์ด์ง ๋์์ธ]


[์ ์ ํ์ด์ง ๋์์ธ]




์ผ๋จ ์ฃผ๋ฌธ์์ฝ ํผ ํ์ด์ง ์ด๊ธฐ ๋์์ธ์ ์ด๋ฌํ๋ค.
๋์ถฉ ์ ์ ํ์ด์ง๋ ๋ฐฐ๋ฌ์ ๋ฏผ์กฑ + ๋ค์ด๋ฒ ํ๋ ์ด์ค๋ฅผ ์ฐธ๊ณ ํ๊ณ
๊ด๋ฆฌ์ ์ชฝ์ ์ฌ์ฉํด๋ณด์ง์์์ ์ด๋ค ๋ฐฉ๋ฒ์ด ์ข์์ง ๋ชฐ๋ผ ๊ทธ๋ฅ ๋๋ฆฌ๋๋๋ก ์ง์ ๋์์ธํ๋ค.
2) ๊ธฐ๋ฅ ๊ตฌํ ๊ตฌ์ (์นดํ ๊ณ ๋ฆฌ ๊ณ์ธต ๊ตฌ์กฐ)


๊ธฐ๋ฅ ๊ตฌํ ๊ตฌ์์ ํ๋ก์ ํธ ์์ ์ ์ .. ์ค์ํ ๋ฉ์ธ ๊ธฐ๋ฅ์ ๋งก์๋ ํฐ๋ผ
์ด๋ค์์ผ๋ก ๊ตฌํํด์ผํ๋ ๊ณ ๋ฏผ๋ ์ปธ๊ณ .. ์ฒ์ ๊ตฌํํด๋ณธ ๊ฒ์ด๋ผ์ ๊ณ ๋ฏผ์ด ์ปธ๋ค..
์๋ ๋์ ์ธ ๊ฒ๋ค์ ํ์๋ค์๊ฒ ๋ฉ์ธ ๊ธฐ๋ฅ ๊ตฌํ์ ๋ํด ๊ฒํ ๋ฐ ์ค๋ช ์ ํ ๋ ์์ ํด๋ ๊ฒ์ด๋ค..
(์ด๋ฐ ๋๋~ ์ผ๋ก ์์ ํ ๊ฒ ๊ฐ๋ค๊ณ ์ค๋ช ํ์)
์ด๊ธฐ์๋
์ฃผ๋ฌธ ํผ๋ ๋๋ถ๋ฅ์ ์ค๋ถ๋ฅ ์๋ถ๋ฅ๋ก ๋๋๊ธฐ ๋๋ฌธ์ ์นดํ ๊ณ ๋ฆฌ ๋๋์ผ๋ก ๊ตฌํํ๋ฉด ๋๊ฒ ๋ค๊ณ ์๊ฐํ๋ค.
๋๋ถ๋ฅ๋ ๊ทธ๋๋ก ๊ฐ๊ณ
์ค๋ถ๋ฅ๋ ๋๋ถ๋ฅ ํค๋ฅผ ๊ฐ์ ธ๊ฐ๊ณ
์๋ถ๋ฅ๋ ์ค๋ถ๋ฅ ํค๋ฅผ ๊ฐ์ ธ๊ฐ๋ค.
์ ๋ฐฉ๋ฒ๋๋ก ์ ์์ ์ธ(?) ๋๋์ผ๋ก ํ ์ด๋ธ 3๊ฐ๋ฅผ ๋ง๋ค์ด์ ๊ตฌํํด๋ณด๋ ค๊ณ ํ๋ค. (์ ๊ทํ๋ ๊ณ์ธต ๋ชจ๋ธ)
๊ทธ๋ฐ๋ฐ ์ด๋ ๊ฒ ๊ตฌํํ ๊ฒฝ์ฐ ์ด๋ ค์์ด JOIN ์ด ๋ง์์ ธ์ ๋๋ฌด ๋ณต์กํด์ง๋ค๋ ๊ฒ์ด๋ค.
๊ทธ๋์ ํ ์ด๋ธ ํ๋์ level ์ปฌ๋ผ์ ๋ฃ์ด์ ๋ถ๋ฅํ๊ธฐ๋ก ํ๋ค. (ํธ๋ฆฌ ๊ณ์ธต ๊ตฌ์กฐ)

์ด๋ ๊ฒ ํธ๋ฆฌ ๊ณ์ธต ๊ตฌ์กฐ๋ก ๊ตฌํํ๋ ๊ฒฝ์ฐ
์ฅ์
1) JOIN ์ด ์์ด ๋งค์ฐ ํธ๋ฆฌํ๊ณ
2) ์ ๋ฐ์ ์ผ๋ก ๋ฐ์ดํฐ ๊ด๋ฆฌ๊ฐ ์ฝ๋ค.
3) 123๋จ๊ณ ๋ฟ๋ง์๋๋ผ 45๋จ๊ณ๊น์ง ๊น์ ๊ตฌ์กฐ๊น์ง ๊ตฌํ ๊ฐ๋ฅ.
๋จ์
1) ๊ณ์ธตํ ๋ฐ์ดํฐ๋ผ ์ฟผ๋ฆฌ๊ฐ ์ด๋ ค์์ง๋ค. (์ฌ๊ท ์ฟผ๋ฆฌ๊ฐ ํ์ํ ์ ์์) -> ์คํ๋ ค JOIN ๋ณด๋ค ์ด๋ ค์ด ์ฟผ๋ฆฌ๊ฐ ๋ฐ์ํ ์ง๋..
2) ํธ๋ฆฌ ๊ตฌ์กฐ๊ฐ ๊น์ผ๋ฉด ์ฌ๊ท ์ฟผ๋ฆฌ ์ฑ๋ฅ์ด ์ ํ ์ฐ๋ ค
์นดํ ๊ณ ๋ฆฌ ๊ฐ์๊ฐ ๋ง์ง ์์ ๊ฒฝ์ฐ์๋ ํด๋น ๋ฐฉ๋ฒ๋ ๋์์ง ์๋ค๊ณ ํ๋จํ๊ณ ..
์ฌ๋ฌํ ์ด๋ธ๋ก JOIN ์ด ๋ง์์ง๋๊ฒ ๋ฒ๊ฑฐ๋ก์ ๊ธฐ ๋๋ฌธ์
ํ ํ ์ด๋ธ์์ ๊ด๋ฆฌํ๊ธฐ๋ก ๋ง์ ๋จน์๋ค.
category ํ ์ด๋ธ


๋จผ์ ์นดํ ๊ณ ๋ฆฌ์ ๋ชจ๋ ์นดํ ๊ณ ๋ฆฌ ๋ ๋ฒจ๋ค์ ๋ฃ๊ฒ๋๋ค.
category_level ์๋ 1,2,3 ์ผ๋ก ๋๋ถ๋ฅ, ์ค๋ถ๋ฅ, ์๋ถ๋ฅ๋ฅผ ๊ตฌ๋ถํ๋ค.
sub_category_status ํ ์ด๋ธ

๊ทธ๋ฆฌ๊ณ ์ค๋ถ๋ฅ ์ํ๊ฐ ํ ์ด๋ธ์ ๋ฐ๋ก ๋บ๋๋ฐ
ํด๋น ํ ์ด๋ธ์ ๋ ๋ฒจ์ด 2์ธ (์ค๋ถ๋ฅ) ์ ํด๋นํ๋ ๊ฐ๋ค์ TYPE ์ ํํํ๋ค.

์ ํ(ํ๋,๋ค์ค) , ์ซ์, ํ ์คํธ | ์ ๋ฃ,๋ฌด๋ฃ | ํ์,์ ํ
์ ์ต์ ๊ฐ์ ์ ์ฅํ๋ ํ ์ด๋ธ์ด๋ผ๊ณ ๋ณด๋ฉด ๋๊ฒ ๋ค.
category_img ํ ์ด๋ธ

๋๋ถ๋ฅ์๋ง ์ฌ์ง์ 1๊ฐ์ฉ๋ง ๋ฃ์ ์ ์๊ฒ ๊ตฌํํ๋ค.
๊ทธ๋์ level 1 ์ธ ๋๋ถ๋ฅ ๊ฐ๊ณผ 1:1 ๋์ํ๋ค.
3) ๊ธฐ๋ฅ ๊ตฌํ (์ฝ๋) - ๊ด๋ฆฌ์ Part
INSERT

ํ๋ก ํธ์์๋ ์๋์ ๊ฐ์ JSON ํํ๋ก ์๋ฒ๋ก ์์ฒญ์ด ์จ๋ค.
JSON ๊ตฌ์กฐ
๋๋ถ๋ฅ
๊ธฐ์ค์ผ๋ก ์ค๋ถ๋ฅ ๋ฐฐ์ด
์์ ์๋ถ๋ฅ ๋ฐฐ์ด
{ "serviceName": "ํ์ดํธ ์ด์ฝ๋ฆฟ ์ผ์ดํฌ", "servicePrice": "12000", "serviceContent": "๋ฌ์ฝคํ ํ์ดํธ ์ด์ฝ๋ฆฟ ์ผ์ดํฌ", "categories": [ { "serviceName": "ํฌ์ฅ์ ๋ฌด", "servicePrice": 0, "isPaid": "N", "isRequired": "Y", "subCategoryType": "SELECT1", "subCategories": [ { "serviceName": "X", "servicePrice": 0 }, { "serviceName": "O", "servicePrice": 0 } ] } ], "serviceStart": "2025-02-07T00:00", "dateNumCase": 10, "timeNumCase": 0, "storeNo": "1" }
DTO
package com.example.HiMade.admin.dto; import com.fasterxml.jackson.annotation.JsonProperty; import lombok.*; import java.time.LocalDate; import java.time.LocalDateTime; import java.util.List; @AllArgsConstructor @NoArgsConstructor @Getter @Setter @ToString @Builder public class adminReserveAdd { private String serviceName; private int servicePrice; private String serviceContent; private List<adminRSDTO> categories; private LocalDateTime serviceStart; private Integer dateNumCase; private Integer timeNumCase; private Integer storeNo; private String storeId; private Integer categoryId; private LocalDate reservationSlotDate; }
package com.example.HiMade.admin.dto; import lombok.*; import java.util.List; @AllArgsConstructor @NoArgsConstructor @Getter @Setter @ToString public class adminRSDTO { private int middleId; // sql private int subId; private int categoryId; private int storeNo; private int categoryLevel; // 1,2,3 private int parentCategoryId; // {cateId} private int categoryStatus; //id private String serviceName; private int servicePrice; private String serviceContent; private String subCategoryType; private String isRequired; private String isPaid; private List<adminReservationDTO> subCategories; }
package com.example.HiMade.admin.dto; import lombok.*; import java.time.LocalDate; import java.time.LocalDateTime; @AllArgsConstructor @NoArgsConstructor @Getter @Setter @ToString @Builder public class adminReservationDTO { private int categoryId; private int categoryLevel; private int parentCategoryId; private String serviceName; private int servicePrice; private String serviceContent; private int storeNo; private LocalDateTime ServiceStart; private String imageUrl; private String activated; private Integer orderIndex; }
๋๋ถ๋ฅ ์ฝ์

<!-- ์๋น์ค (๋๋ถ๋ฅ) ๋ฑ๋กํ๊ธฐ --> <insert id="setMainCategory" parameterType="com.example.HiMade.admin.dto.adminReservationDTO" useGeneratedKeys="true" keyProperty="categoryId"> INSERT INTO category (category_level, service_name, service_price, service_content,store_no, service_start, activated) VALUES (1, #{serviceName}, #{servicePrice}, #{serviceContent}, #{storeNo}, #{serviceStart} , 'Y') RETURNING category_id </insert>
level 1 ๋ก ๋ค์ด๊ฐ ๋๋ถ๋ฅ์ ํ์ํ ๊ฐ๋ค์ ๋ฃ๊ณ ๋จผ์ INSTERT ํ category_id
๋ฅผ ๋ฐํ ๋ฐ๋๋ค.
useGeneratedKeys="true"
: ์๋์์ฑ๋ ํค๋ฅผ ์ฌ์ฉํ์ฌ ์ฝ์
๋ฐ์ดํฐ ์ถ์
keyProperty="categoryId"
: ์๋ ์์ฑ๋ ํค ๊ฐ์ ์ ์ฅํ dto ํ๋ ๋ช
์ง์
RETURNING category_id
: sql ์ฝ์
ํ ์์ฑ ๋ ๊ฐ์ ๋ฐํ (์นดํ
๊ณ ๋ฆฌ ํค ๊ฐ์ ธ์ค๋ ์ฉ๋)
์ค๋ถ๋ฅ & ์๋ถ๋ฅ ์ฝ์
List<adminRSDTO> categories = dto.getCategories(); // ์ค๋ถ๋ฅ LIST ๊ฐ์ ธ์ค๊ธฐ for (adminRSDTO category : categories) { // ์ค๋ถ๋ฅ LIST ์ํ category.setStoreNo(dto.getStoreNo()); category.setParentCategoryId(serviceId); // ๋๋ถ๋ฅ ID๋ฅผ ์นดํ
๊ณ ๋ฆฌ์ ์ค์ int serviceId2 = adminReservationMapper.setMainCategory2(category); // ์ค๋ถ๋ฅ INSERT adminReservationMapper.setMainCategory3(category); // ์ค๋ถ๋ฅ ์ํ INSERT List<adminReservationDTO> subCategories = category.getSubCategories(); // ์๋ถ๋ฅ LIST ๊ฐ์ ธ์ค๊ธฐ for (adminReservationDTO subcategory : subCategories) { subcategory.setStoreNo(dto.getStoreNo()); subcategory.setParentCategoryId(serviceId2); // ์ฝ์
๋ ์ค๋ถ๋ฅ ์์ด๋๋ฅผ ๋ถ๋ชจ ์์ด๋๋ก ๊ฐ์ง๊ณ ๊ฐ adminReservationMapper.setMainCategory4(subcategory); // ์๋ถ๋ฅ insert } }
์ดํ ์ค๋ถ๋ฅ LIST ๋ฅผ ์ํํ๋ฉด์ ์ค๋ถ๋ฅ์ ์ค๋ถ๋ฅ ์ํ๋ฅผ ์ฝ์ ํด์ฃผ๊ณ
๊ฐ ์ค๋ถ๋ฅ์ ํด๋นํ๋ ์๋ถ๋ฅ๋ ์ฝ์ ํด์ค๋ค.
(๋๋ถ๋ฅ์ ๋ง์ฐฌ๊ฐ์ง๋ก ์ฝ์ ํ PK ๊ฐ ๋ฐํํด์์ ์ฌ์ฉ)
<!-- ์๋น์ค (์ค๋ถ๋ฅ) ๋ฑ๋กํ๊ธฐ --> <insert id="setMainCategory2" parameterType="com.example.HiMade.admin.dto.adminRSDTO" useGeneratedKeys="true" keyProperty="middleId"> INSERT INTO category (category_level, parent_category_id, service_name, service_price, store_no) VALUES (2, #{parentCategoryId}, #{serviceName}, #{servicePrice},#{storeNo}) RETURNING category_id </insert> <!-- ์๋น์ค (์ค๋ถ๋ฅ ์ํ๊ฐ ) ๋ฑ๋กํ๊ธฐ --> <insert id="setMainCategory3" parameterType="com.example.HiMade.admin.dto.adminRSDTO"> INSERT INTO sub_category_status (category_id, sub_category_type, is_required, is_paid) VALUES (#{middleId}, #{subCategoryType}, #{isRequired}, #{isPaid}); </insert> <!-- ์๋น์ค (์๋ถ๋ฅ) ๋ฑ๋กํ๊ธฐ --> <insert id="setMainCategory4" parameterType="com.example.HiMade.admin.dto.adminReservationDTO"> INSERT INTO category (category_level, parent_category_id, service_name, service_price, store_no) VALUES (3, #{parentCategoryId}, #{serviceName}, #{servicePrice}, #{storeNo}) </insert>
๋ก๊ทธ
adminReserveAdd(serviceName=ํ์ดํธ ์ด์ฝ๋ฆฟ ์ผ์ดํฌ, servicePrice=12000, serviceContent=๋ฌ์ฝคํ ํ์ดํธ ์ด์ฝ๋ฆฟ ์ผ์ดํฌ, categories=[adminRSDTO(middleId=0, subId=0, categoryId=0, storeNo=0, categoryLevel=0, parentCategoryId=0, categoryStatus=0, serviceName=ํฌ์ฅ์ ๋ฌด, servicePrice=0, serviceContent=null, subCategoryType=SELECT1, isRequired=Y, isPaid=N, subCategories=[adminReservationDTO(categoryId=0, categoryLevel=0, parentCategoryId=0, serviceName=X, servicePrice=0, serviceContent=null, storeNo=0, ServiceStart=null, imageUrl=null, activated=null, orderIndex=null), adminReservationDTO(categoryId=0, categoryLevel=0, parentCategoryId=0, serviceName=O, servicePrice=0, serviceContent=null, storeNo=0, ServiceStart=null, imageUrl=null, activated=null, orderIndex=null)])], ServiceStart=2025-02-07T00:00, DateNumCase=10, TimeNumCase=0, StoreNo=1, StoreId=null, categoryId=null, reservationSlotDate=null) ๋ฉ์ธ ์นดํ
๊ณ ๋ฆฌ ์ฝ์
ํ ์์ด๋ : 59 ์ค๋ถ๋ฅ ์นดํ
๊ณ ๋ฆฌ ์ฝ์
ํ : 60 adminReservationDTO(categoryId=0, categoryLevel=0, parentCategoryId=0, serviceName=X, servicePrice=0, serviceContent=null, storeNo=0, ServiceStart=null, imageUrl=null, activated=null, orderIndex=null) ์๋ถ๋ฅ ์ฝ์
๋จ 1 adminReservationDTO(categoryId=0, categoryLevel=0, parentCategoryId=0, serviceName=O, servicePrice=0, serviceContent=null, storeNo=0, ServiceStart=null, imageUrl=null, activated=null, orderIndex=null) ์๋ถ๋ฅ ์ฝ์
๋จ 2
SELECT
@Override public adminReservationDTO getListDetail(int id) { return adminReservationMapper.getListDetail(id); } @Override public List<adminRSDTO> getMiddleItem(int id) { List<adminRSDTO> dto = adminReservationMapper.getMiddleItem(id); System.out.println("service dto :: " + dto ); for (adminRSDTO d : dto ){ System.out.println(d); System.out.println(); d.setSubCategories(adminReservationMapper.getSubItem(d.getCategoryId())); } System.out.println(dto); return dto; }
useEffect(() => { axios .get(`/adminReservation/getListDetail/${cateId}`) .then(response => { console.log(response.data); setReserveModi(response.data); const { imageUrl,serviceContent,serviceName,servicePrice,serviceStart} = response.data; setImagePreview(imageUrl); setName(serviceName); setPrice(servicePrice); setDescription(serviceContent); setServiceStart(serviceStart); }) .catch(error => { console.log('์๋ฌ', error); }); axios .get(`/adminReservation/getMiddleItem/${cateId}`) .then(response => { console.log("get" + JSON.stringify(response.data)); const transformedData = response.data.map(item => ({ serviceName: item.serviceName, // serviceName -> name servicePrice: item.servicePrice, // servicePrice -> price isPaid: item.isPaid === 'Y', // isPaid ("Y"/"N") -> true/false isRequired: item.isRequired === 'Y', // isRequired ("Y"/"N") -> true/false subCategoryType: item.subCategoryType, // subCategoryType -> inputType subCategories: item.subCategories.map(sub => ({ serviceName: sub.serviceName, servicePrice: sub.servicePrice })) })); setCategories(transformedData); }) .catch(error => { console.log('์๋ฌ', error); }); }, [cateId]);
<!-- ์๋น์ค ๋๋ถ๋ฅ (์์ธ ๊ฐ์ ธ์ค๊ธฐ) --> <select id="getListDetail" resultType="com.example.HiMade.admin.dto.adminReservationDTO"> select c.category_id, c.category_level, c.parent_category_id, c.service_name , c.service_price, c.service_content, c.store_no, ci.image_url, c.service_start from category c left join category_image ci on c.category_id = ci.category_id where c.category_level = 1 AND c.category_id = #{id} </select> <!-- ์๋น์ค ์ค๋ถ๋ฅ ๊ฐ์ ธ์ค๊ธฐ --> <select id="getMiddleItem" resultType="com.example.HiMade.admin.dto.adminRSDTO"> select c.category_id, c.category_level, c.parent_category_id, c.service_name , c.service_price, c.service_content, c.store_no, sc.category_status, sc.category_id, sc.sub_category_type, sc.is_required, sc.is_paid from category c LEFT join sub_category_status sc on c.category_id = sc.category_id WHERE c.parent_category_id = #{id} AND c.category_level = 2 </select> <!-- ์๋น์ค ์๋ถ๋ฅ ๊ฐ์ ธ์ค๊ธฐ --> <select id="getSubItem" resultType="com.example.HiMade.admin.dto.adminReservationDTO"> select * from category c where parent_category_id = #{id} AND category_level = 3; </select>
์กฐํ ๊ฐ์ ๊ฒฝ์ฐ์๋ ๋๋ถ๋ฅ ์ ์ค๋ถ๋ฅ|์๋ถ๋ฅ๋ฅผ ๋๋ ์ ๊ฐ์ ธ์๋ค.
(ํด๋น ์ฟผ๋ฆฌ๋ ์๋นํ ๋นํจ์จ์ ์ธ ๊ฒ ๊ฐ์์ JOIN ์ ์ด์ฉํด ํ๋ฒ์ ๊ฐ์ ธ์ค๋ ๋ฐฉ์์ ์ฐ์ตํด๋ด์ผ๊ฒ ์)
UPDATE
์ด๊ฑด ๊ทธ๋ฅ ๊ธฐ์กด ๊ฐ์ ์ ๊ฑฐํ๊ณ ์๋ก ์ฝ์ ํ๋ ๋ฐฉ์์ผ๋ก ๊ตฌํํ๋ค.
(์์ ๊ธฐ๋ฅ ๊ตฌํ์ด ๋๋ฌด.. ํ๋ค์๋ค... )
DELETE
์ด๊ฑด ๋๋ถ๋ฅ ๊ฐ์ activated
๊ฐ์ Y / N ์ผ๋ก ํด์ ๊ตฌํํ๋ค.
4) ๊ธฐ๋ฅ ๊ตฌํ (์ฝ๋) - ์ฌ์ฉ์ Part

์ฌ์ฉ์ ํํธ์์ ์นดํ ๊ณ ๋ฆฌ ์กฐํํด์ค๋ ๋ฐฉ์์ ๊ด๋ฆฌ์ ํํธ์ฒ๋ผ ์กฐํ ํด์ค๋ ๋ฐฉ์์ ๋์ผํ๊ณ ๋ณด์ฌ์ฃผ๋ ๋ฐฉ์๋ง ๋ค๋ฅด๋ค.
5) ํ๊ธฐ
- โ ํ์ฌ ์นดํ ๊ณ ๋ฆฌ์์ SELECT ํด์ค๋ ์ฟผ๋ฆฌ๋ค์ด ๋นํจ์จ์ ์ด๋ฏ๋ก, ๋ณด๋ค ํจ์จ์ ์ธ ์ฟผ๋ฆฌ๋ฅผ ์์ฑํด๋ณผ ๊ฒ
- โ ํ ์ด๋ธ ๋ด์ ๋๋ฌด ๋ค์ํ ์ปฌ๋ผ๊ณผ ๋ฐ์ดํฐ๋ค์ด ํผ์ฌ๋์ด ์์ผ๋ฏ๋ก, ์ด๋ฅผ ์ ๋ถ๋ฅํ์ฌ ๊ตฌ์กฐ๋ฅผ ๊ฐ์ ํด๋ณผ ๊ฒ