본문 바로가기
728x90

개발/DBMS 7

Transaction - 트랜잭션 이번 글에서는 Transaction (이하 트랜잭션) 이라는 것에 대해 말해보겠다. 본인도 트랜잭션을 알게 된지는 그리 오래되지 않았다. 그리고 그 필요성도 딱히 느끼지 못 했었다. 따라서, 혼자 개발 공부할 때에는 트랜잭션을 사용하지 않았다. 하지만 회사 프로젝트에서는 대부분 트랜잭션을 사용하고 있었다. 그래서 트랜잭션을 좀 더 관심있게 보게 됐다. 사실, 회사에서 쓸 프로젝트에 본인이 Stored Procedure를 개발할 일이 있었는데 이 때 트랜잭션을 쓰지 않고 개발했다가 혼이 났다 ㅎㅎㅎ 그래서 실수를 다시 하지 않기 위해 기록을 남기겠다. 여기선, 트랜잭션이란 무엇이며 왜 그리고 언제 사용하는가? 에 대해 다뤄보겠다. (트랜잭션의 역사나 유래나 이런 것은 잘 모른다. 이건 자료를 찾아봐야하는데.. 2020. 11. 13.
JOIN 문제 해결 앞서 살펴본 tables 간의 관계로 인한 Join 문제가 있었다. 1:N의 data가 생기면 어떤 data를 filtering해야 원하는 data가 나올까... 자! 이제 그 해결방법을 알아보자. 먼저 본인이 고민하고 고민해서 작성한 query는 아래와 같았다. SELECTSV.ServerName ,SV.ServerIP ,SV.AccountInfo = CASE WHEN EXISTS(SELECT * FROM dbo.ServersPermissions AS SVP INNER JOIN dbo.Users AS US ON (SVP.PermitTo = US.UserNo) WHERE SV.VMName = SVP.VMName AND US.PersonNo = @LoggedUser) THEN 'ID: ' + SV.Acco.. 2020. 11. 11.
문자+숫자 DB 컬럼 정렬하기 DB 컬럼을 정렬할 때 간혹 컬럼 data가 문자+숫자로 되어 있어서 정렬이 이상하게 될 때가 있다. 가령 아래와 같다. SELECT * FROM VirtualMachines; 이런 경우에는 SELECT * FROM VirtualMachines ORDER BY VMName; 이렇게 수행해도 같은 결과가 나온다. 숫자의 정렬방식은 1, 10, 2, 3, 4, 5, 50 ... 이런 식이기 때문이다. 그럼 어떻게 변경해야할까? SELECT * FROM VirtualMachines ORDER BY LEN(VMName), VMName; 이런식으로 변경해주면 된다. LEN 이란 문자열의 길이를 반환해주는 함수이다. (같이 알아두면 좋은 것은 DATALENGTH 함수이니, 찾아보길 바란다.) 문자열의 길이로 먼저 .. 2020. 11. 9.
JOIN 문제 오늘은 SQL을 다루면서 있었던 문제에 대해서 설명하면서, 어떻게 해결해나갈지 고민해보겠다. 아래 Table들이 있다고 하자. 상황은 아래와 같다. 1. 모든 Servers의 목록을 보여준다. 단, Login user가 각각의 Server에 접근권한(Permission)이 있는 경우에만 Server에 Login할 수 있는 ID와 PW를 볼 수 있다. (권한이 없으면 No permission 이라고 띄운다.) 2. ServersPermissions의 PK는 ServerName과 PermitTo를 합친 것이다. 3. 하나의 Server에는 여러 users가 권한(Permission)을 가질 수 있다. 즉, ServersPermissions Table에는 하나의 serverName과 여러 User가 매칭된다는.. 2020. 11. 5.
RDBMS 정규화(Normalization) - 2/2 지난 글에서 RDBMS 정규화가 왜 필요한지 이상현상(Anomaly)과 함께 설명하였다. 정규화가 6단계로 이뤄져있다는 것도 간략히 알아봤다. 그럼 이제 정규화에 대해서 본격적으로 알아보겠다. * 참, 정규화는 단계가 점점 높아지는데 상위 단계의 정규화는 하위 단계의 정규화를 만족하고 있다는 것을 알아야한다. 1. 1차 정규화(1NF) - 원자값으로 구성 위 Tables을 보자. 첫 번째 table에는 한 user에게 email 주소가 두 개 들어가 있다. 이게 원자값으로 구성되지 않다고 볼 수 있다. 여기서 문제는 가령 유저가 하나의 email 주소를 변경했을 때, 기존 email에 값에서 변경된 값을 찾아서 다시 넣어줘야한다거나 다 가져와서 변경된 걸 찾아넣고 모두 덮어쓰기를 한다거나의 문제가 있을 .. 2020. 9. 27.
RDBMS 정규화(Normalization) - 1/2 정규화(Normalization)의 개념 정규화란 뭘까? 우리가 흔히 DB라고 알고 있는 RDBMS(Relational DataBase Management System)를 설계할 때, 중복을 최소화하면서 데이터 구조를 짜는 프로세스이다. 그렇다면 왜 중복을 최소화하는 정규화를 할까? 이를 하지 않으면 이상 현상(Anomaly)이 발생하기 때문이다. 이상 현상(Anomaly)이란? 정규화를 적절히 하지 않은 DB 또는 Relation(Table)에 데이터가 중복되고 이 Table에 어떠한 작업을 할 때 비합리적인 문제들이 발생하는 현상이다. * Relation은 행(Rows)과 열(Columns)로 구성된 Table이다. 이상현상은 아래와 같다. 이상 현상 설명 삽입이상 데이터를 테이블에 저장할 때, 불필.. 2020. 9. 24.
728x90