์ „์ฒด ๊ธ€

Spring Framework/๐Ÿ“› ์—๋Ÿฌ ๊ธฐ๋ก

[๐Ÿ“› Error] deleteAll()๊ณผ deleteAllInBatch()์˜ ์ฐจ์ด

DB์— ์žˆ๋Š” ๋ฐ์ดํ„ฐ๋“ค์„ ๋ชจ์กฐ๋ฆฌ ์‚ญ์ œํ•˜๊ณ  ๋‹ค์‹œ save ํ•ด์•ผํ–ˆ๋‹ค.์ฒ˜์Œ์—๋Š” deleteAll()๋กœ ์‚ญ์ œํ•œ ํ›„ saveAll()ํ•˜๋Š” ๊ฒƒ์œผ๋กœ ์ฝ”๋“œ๋ฅผ ์ž‘์„ฑํ–ˆ๋‹ค.ํ•˜์ง€๋งŒ ์‹คํ–‰์‹œ์ผœ๋ณด๋‹ˆ ์œ„์™€ ๊ฐ™์€ ์—๋Ÿฌ๊ฐ€ ๋ฐœ์ƒํ–ˆ๋‹ค.ย delete๊ฐ€ ๋˜์ง€ ์•Š๊ณ  save๋ฅผ ํ•˜๋ ค๊ณ  ํ•˜๋‹ˆ ์ค‘๋ณต๋œ ํ‚ค๊ฐ€ ์žˆ๋‹ค๊ณ  ๋‚˜์˜ค๋Š” ๋“ฏํ•˜๋‹ค.ย ย ย ย deleteAll()์ฃ„๋‹ค select๋งŒ ํ•˜๊ณ  delete๋Š” ํ•˜์ง€ ์•Š์•˜๋‹ค.๊ฒฐ๊ตญ delete๋ฅผ ํ•˜์ง€ ์•Š๊ณ  saveAll()์„ ๋งŒ๋‚˜ insertํ•˜๋ ค๊ณ  ํ•œ๋‹ค.ย ๊ทธ๋Ÿฌ๋‹ค ๋ณด๋‹ˆ ์ค‘๋ณต๋œ ํ‚ค๊ฐ€ ์žˆ๋‹ค๋Š” ์˜ค๋ฅ˜๊ฐ€ ๋ฐœ์ƒํ•œ ๊ฒƒ์ด๋‹ค.ย ๐Ÿ”น deleteAll()ย deleteAll() ๋ฉ”์„œ๋“œ๋ฅผ ๋“ค์–ด๊ฐ€์„œ ํ™•์ธํ•ด๋ณด๋‹ˆ findAll()๋กœ ๋ชจ๋“  ์—”ํ‹ฐํ‹ฐ๋ฅผ ์ฐพ๊ณ  ํ•˜๋‚˜์”ฉ ์‚ญ์ œํ•œ๋‹ค.ย ๊ฐ ์—”ํ‹ฐํ‹ฐ๋ฅผ ๊ฐœ๋ณ„์ ์œผ๋กœ ์‚ญ์ œํ•˜๊ณ , ํŠธ๋žœ์žญ์…˜์ด commit๋  ๋•Œ๋งˆ๋‹ค ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์— ..

Spring Framework/JPA

[JPA] @Column(unique=true)์™€ @UniqueConstraint

[Failed to add the foreign key constraint. Missing index for constraint 'FKe6nwysthx2dnq1ikoe3u9gkxp' in the referenced table 'area']ย ์ด ERROR๊ฐ€ ์ฐธ ๊ฑฐ์Šฌ๋ ธ๋‹ค.ย ERROR์ž„์—๋„ ๋ฐ์ดํ„ฐ๊ฐ€ ์•Œ๋งž๊ฒŒ ๋“ค์–ด๊ฐ”๊ธฐ ๋•Œ๋ฌธ์ด๋‹ค.ย ย ๋Œ€์ถฉ ์–ด๋–ค ์—๋Ÿฌ์ธ์ง€๋Š” ํŒŒ์•…ํ–ˆ๋‹ค.area_code๊ฐ€ unique ์กฐ๊ฑด์ด ๊ฑธ๋ ค์žˆ์ง€ ์•Š๊ธฐ ๋•Œ๋ฌธ์— FK ์ œ์•ฝ์กฐ๊ฑด์„ ์ƒ์„ฑํ•  ์ˆ˜ ์—†๋‹ค๋Š” ๊ฒƒ์ด๋‹ค.ย ์–ด๋–ค ์ƒํ™ฉ์ธ์ง€...Weather ์—”ํ‹ฐํ‹ฐ์™€ Area ์—”ํ‹ฐํ‹ฐ๊ฐ€ ์ผ๋Œ€์ผ ๋งคํ•‘๋˜์–ด์žˆ๊ณ ,referencedColumnName ์˜ต์…˜์„ ์ค˜์„œ AREA_CODE๋กœ Area ํ•„๋“œ๋ฅผ ์ฐธ์กฐํ–ˆ๋‹ค.ย @Entity@Table(name = "WEATHER")public class ..

์•Œ๊ณ ๋ฆฌ์ฆ˜/BOJ

[BOJ] 2457 ๊ณต์ฃผ๋‹˜์˜ ์ •์›

โœจ ๊ทธ๋ฆฌ๋”” & ์ •๋ ฌ https://www.acmicpc.net/problem/2457 2457๋ฒˆ: ๊ณต์ฃผ๋‹˜์˜ ์ •์› ์ฒซ์งธ ์ค„์—๋Š” ๊ฝƒ๋“ค์˜ ์ด ๊ฐœ์ˆ˜ N (1 โ‰ค N โ‰ค 100,000)์ด ์ฃผ์–ด์ง„๋‹ค. ๋‹ค์Œ N๊ฐœ์˜ ์ค„์—๋Š” ๊ฐ ๊ฝƒ์ด ํ”ผ๋Š” ๋‚ ์งœ์™€ ์ง€๋Š” ๋‚ ์งœ๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. ํ•˜๋‚˜์˜ ๋‚ ์งœ๋Š” ์›”๊ณผ ์ผ์„ ๋‚˜ํƒ€๋‚ด๋Š” ๋‘ ์ˆซ์ž๋กœ ํ‘œํ˜„๋œ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด์„œ, www.acmicpc.net ๐Ÿ“ ๊ณ ๋ คํ•ด์•ผํ•  ์  ๋‚ ์งœ๋ฅผ ๋น„๊ตํ•˜๊ธฐ ์œ„ํ•ด ์ž…๋ ฅ์œผ๋กœ ์ฃผ์–ด์ง„ ์ •๋ณด๋ฅผ ๋Œ€์†Œ๋น„๊ต ๊ฐ€๋Šฅํ•˜๊ฒŒ๋” ์ •์ˆ˜๋กœ ๋ฐ”๊พธ๊ธฐ 3/1 ~ 11/30 ๊นŒ์ง€๋งŒ ํ™•์ธํ•˜๋ฉด ๋œ๋‹ค. ๊ฝƒ์ด ์ง€๋Š” ๋‚ ์—๋Š” ๊ฝƒ์„ ๋ณผ ์ˆ˜ ์—†๋‹ค. ์ž…๋ ฅ์œผ๋กœ ์ฃผ์–ด์ง„ ๋‚ ์งœ๋ฅผ ๊ฝƒ์ด ํ•€ ๋‚ ์งœ๊ฐ€ ์ด๋ฅธ ์ˆœ, ๋งŒ์•ฝ ํ•€ ๋‚ ์งœ๊ฐ€ ๊ฐ™๋‹ค๋ฉด ์ง„ ๋‚ ์งœ๊ฐ€ ์ด๋ฅธ ์ˆœ์œผ๋กœ ์ •๋ ฌ์‹œ์ผœ์•ผ ํ•œ๋‹ค. ๐Ÿ•น๏ธ ํ’€์ด ๊ณผ์ • ๋ชป ํ’€์–ด์„œ ํ’€์ด๋ฅผ ๋ณด๊ณ  ๋‹ค์‹œ ํ’€์—ˆ๋‹ค. Olympia..

DevOps/โ›“๏ธ CI&CD

[โ›“๏ธCI/CD] GitHub Actions - AWS CodeDeploy & S3 ์ด์šฉํ•ด์„œ ๋ฐฐํฌ

์ด์ „ ๊ธ€์—์„œ GitHub Actions๋ฅผ CI์˜ ์šฉ๋„๋กœ ์‚ฌ์šฉํ–ˆ๊ณ , ์ฝ”๋“œ์˜ ์ž๋™ ๋ฐฐํฌ๋ฅผ ์œ„ํ•œ AWS CodeDeploy๋ฅผ ๊ตฌํ˜„ํ•ด๋ณด๊ฒ ๋‹ค. GitHub Actions๋ฅผ ์‚ฌ์šฉํ•ด์„œ CI๋ฅผ ๊ตฌ์ถ•ํ•˜๊ณ , AWS CodeDeploy๋กœ CD๋ฅผ ๊ตฌ์ถ•ํ•ด ์Šคํ”„๋ง ํ”„๋กœ์ ํŠธ๋ฅผ ์ž๋™ ๋ฐฐํฌํ•  ๊ฒƒ์ด๋‹ค. ๊ฐ„๋‹จ ์š”์•ฝ GitHub์— pushํ•˜๋ฉด GitHub Actions๊ฐ€ ์ž๋™์œผ๋กœ ์‹คํ–‰ ๐Ÿ‘‰ gradlew build ๋ช…๋ น์–ด๋กœ ๋นŒ๋“œํ•˜์—ฌ ์‹คํ–‰ํ•  ์ˆ˜ ์žˆ๋Š” jar ํŒŒ์ผ ์ƒ์„ฑ ๋ฐฐํฌ์— ํ•„์š”ํ•œ jar ํŒŒ์ผ๊ณผ shell script ํŒŒ์ผ์€ ์••์ถ•ํ•ด์„œ zip ํŒŒ์ผ์„ AWS S3๋กœ ์—…๋กœ๋“œ EC2์— ์„ค์น˜๋˜์–ด ์žˆ๋Š” CodeDeploy Agent๊ฐ€ S3์— ์—…๋กœ๋“œ๋œ zip ํŒŒ์ผ์„ ๊ฐ€์ ธ์™€์„œ ๋ฐฐํฌ CodeDeploy Agent๋Š” S3์—์„œ zip ํŒŒ์ผ์„ ๋‚ด๋ ค๋ฐ›๊ณ , appsp..

DevOps/โ›“๏ธ CI&CD

[โ›“๏ธ CI/CD] CI/CD์™€ GitHub Actions ํ™œ์šฉ๋ฒ•

Jenkins์™€ GitHub Actions์˜ ์ฐจ์ด์ ์„ ์•Œ์•„๋ณด๊ธฐ ์œ„ํ•ด ๋‘ ๊ฐ€์ง€ ๋ฐฉ๋ฒ•์„ ๋ชจ๋‘ ์‚ฌ์šฉํ•˜์—ฌ ๋ฐฐํฌ ์ž๋™ํ™”๋ฅผ ์ง„ํ–‰ํ–ˆ๋‹ค. (Jenkins์™€ ๊ด€๋ จ๋œ ๊ธ€๋„ ์ž‘์„ฑํ•˜๊ณ  ์žˆ์œผ๋‚˜ ์›Œ๋‚™ ์ถ”๊ฐ€ํ•  ๋‚ด์šฉ์ด ๋งŽ๋‹ค๋ณด๋‹ˆ ์ž„์‹œ์ €์žฅ์†Œ์— ๋ฌปํžŒ์ง€ ์˜ค๋ž˜๋‹ค.. ) GitHub Actions์€ Jenkins ๋ณด๋‹ค ๊ฐ„๋‹จํ–ˆ๋‹ค. ์‚ฌ์šฉ๋ฒ•์„ ๊ธฐ๋กํ•˜๊ณ  ๋‘˜์˜ ์ฐจ์ด์ ์„ ๊ฐ„๋‹จํ•˜๊ฒŒ ๊ธฐ๋กํ•˜๊ณ ์ž ํ•œ๋‹ค. โ›“๏ธ CI/CD์™€ GitHub Actions CI/CD ๊ฐœ๋…์€ Jenkins์™€ ๊ด€๋ จ๋œ ๊ธ€์„ ์ž‘์„ฑํ•˜๋ฉด์„œ ์–ธ๊ธ‰ํ•˜๊ธด ํ–ˆ์—ˆ๋‹ค. CI/CD(์ง€์†์  ํ†ตํ•ฉ / ์ง€์†์  ๋ฐฐํฌ)๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ์ด์œ ๋Š” ์†Œํ”„ํŠธ์›จ์–ด ๊ฐœ๋ฐœ ์›Œํฌํ”Œ๋กœ์šฐ๋ฅผ ์ž๋™ํ™”ํ•˜๊ธฐ ์œ„ํ•ด์„œ์ด๋‹ค. ๊ถ๊ทน์ ์œผ๋กœ๋Š” ์‚ฌ์šฉ์ž์—๊ฒŒ ๋น ๋ฅด๊ฒŒ ์ตœ์‹  ํ”„๋กœ์ ํŠธ๋ฅผ ์ œ๊ณตํ•˜๊ธฐ ์œ„ํ•ด์„œ์ด๊ธฐ๋„ ํ•˜๋‹ค. ์ง€์†์  ํ†ตํ•ฉ - CI (Continuous Integra..

์•Œ๊ณ ๋ฆฌ์ฆ˜/BOJ

[BOJ] 1202 ๋ณด์„๋„๋‘‘ - Java

โœจ ์šฐ์„ ์ˆœ์œ„ ํ & ์ •๋ ฌ https://www.acmicpc.net/problem/1202 1202๋ฒˆ: ๋ณด์„ ๋„๋‘‘ ์ฒซ์งธ ์ค„์— N๊ณผ K๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. (1 โ‰ค N, K โ‰ค 300,000) ๋‹ค์Œ N๊ฐœ ์ค„์—๋Š” ๊ฐ ๋ณด์„์˜ ์ •๋ณด Mi์™€ Vi๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. (0 โ‰ค Mi, Vi โ‰ค 1,000,000) ๋‹ค์Œ K๊ฐœ ์ค„์—๋Š” ๊ฐ€๋ฐฉ์— ๋‹ด์„ ์ˆ˜ ์žˆ๋Š” ์ตœ๋Œ€ ๋ฌด๊ฒŒ Ci๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. (1 โ‰ค Ci www.acmicpc.net ๐Ÿ“ ๊ณ ๋ คํ•ด์•ผํ•  ์  ํ›”์น  ์ˆ˜ ์žˆ๋Š” ๋ณด์„ ๊ฐ€๊ฒฉ์˜ ์ตœ๋Œ€์˜ ํ•ฉ์„ ๊ตฌํ•ด์•ผ ํ•œ๋‹ค. ๋ณด์„์˜ ๊ฐœ์ˆ˜

์•Œ๊ณ ๋ฆฌ์ฆ˜/BOJ

[BOJ] 1238 ํŒŒํ‹ฐ - Java

โœจ ๊ทธ๋ž˜ํ”„ ๐Ÿ‘‰ ๋‹ค์ต์ŠคํŠธ๋ผ (์ตœ๋‹จ๊ฒฝ๋กœ ํƒ์ƒ‰ ์•Œ๊ณ ๋ฆฌ์ฆ˜) https://www.acmicpc.net/problem/1238 1238๋ฒˆ: ํŒŒํ‹ฐ ์ฒซ์งธ ์ค„์— N(1 โ‰ค N โ‰ค 1,000), M(1 โ‰ค M โ‰ค 10,000), X๊ฐ€ ๊ณต๋ฐฑ์œผ๋กœ ๊ตฌ๋ถ„๋˜์–ด ์ž…๋ ฅ๋œ๋‹ค. ๋‘ ๋ฒˆ์งธ ์ค„๋ถ€ํ„ฐ M+1๋ฒˆ์งธ ์ค„๊นŒ์ง€ i๋ฒˆ์งธ ๋„๋กœ์˜ ์‹œ์ž‘์ , ๋์ , ๊ทธ๋ฆฌ๊ณ  ์ด ๋„๋กœ๋ฅผ ์ง€๋‚˜๋Š”๋ฐ ํ•„์š”ํ•œ ์†Œ์š”์‹œ๊ฐ„ Ti๊ฐ€ ๋“ค์–ด www.acmicpc.net ๐Ÿ“ ๊ณ ๋ คํ•ด์•ผํ•  ์  ๊ฐ ํ•™์ƒ๋“ค์˜ ์ง‘์—์„œ ํŒŒํ‹ฐ ์žฅ์†Œ๊นŒ์ง€ ์˜ค๊ณ  ๊ฐ€๋Š” ๋ฐ ๊ฑธ๋ฆฌ๋Š” ์ตœ๋‹จ ์‹œ๊ฐ„ ๊ตฌํ•˜๊ธฐ ๋„๋กœ๋“ค์€ ๋‹จ๋ฐฉํ–ฅ ๐Ÿ‘‰ ๊ธธ๋งˆ๋‹ค ๊ฑธ๋ฆฌ๋Š” ์‹œ๊ฐ„์ด ๋‹ค๋ฅด๋ฏ€๋กœ ์˜ค๊ณ  ๊ฐ€๋Š” ๊ธธ ๋˜ํ•œ ๋‹ค๋ฆ„ ! N๋ช…์˜ ํ•™์ƒ๋“ค ์ค‘ ์˜ค๊ณ  ๊ฐ€๋Š” ๋ฐ ๊ฐ€์žฅ ๋งŽ์€ ์‹œ๊ฐ„์„ ์†Œ๋น„ํ•œ ํ•™์ƒ ์ถœ๋ ฅ ๐Ÿ•น๏ธ ํ’€์ด๊ณผ์ • ์ง‘์—์„œ ํŒŒํ‹ฐ ์žฅ์†Œ๊นŒ์ง€ ๊ฐ€๋Š” ๋ฐ ๊ฑธ๋ฆฌ๋Š” ์ตœ๋‹จ ์‹œ๊ฐ„ + ํŒŒํ‹ฐ ์žฅ์†Œ์—์„œ..

DevOps/๐Ÿณ Docker

[๐Ÿณ Docker] ๋„์ปค ๋ช…๋ น์–ด ์ •๋ฆฌ - Dockerfile

Docker ์ฃผ์š” ๋ช…๋ น์–ด ๋„์ปค ๋ช…๋ น์–ด ์ฐพ์•„์„œ ์‚ฌ์šฉํ•˜๊ธฐ ๐Ÿ‘‰ https://docs.docker.com/reference/cli/docker/container/rm/ cheatsheet ์‚ฌ์šฉํ•˜๊ธฐ ๐Ÿ‘‰ https://docs.docker.com/get-started/docker_cheatsheet.pdf ๋ช…๋ น์–ด ๊ตฌ์„ฑ : docker ์ปค๋งจ๋“œ (์˜ต์…˜) ๋Œ€์ƒ (์ธ์ž) docker run --name apa03 -d -p 8081:80 httpd docker --version docker ps -a : ์ค‘์ง€๋œ ์ปจํ…Œ์ด๋„ˆ๊นŒ์ง€ ๋ชจ๋‘ ํ™•์ธ docker pull [์ด๋ฏธ์ง€ ์ด๋ฆ„] : docker hub์—์„œ ์ด๋ฏธ์ง€ ๋‹ค์šด๋กœ๋“œ ์‹คํ–‰ ์ค‘์ธ ์ปจํ…Œ์ด๋„ˆ ๋ชจ๋‘ ์‚ญ์ œ docker rm -f $(docker ps -aq) docker run = ..

soogoori
๐Ÿƒ๐Ÿป‍โ™€๏ธ์Šคํ…๋ฐ”์ด์Šคํ…