본문 바로가기

DATABASE/DATABASE

[DATABASE] Sliicon apple Mac (M1) Mysql 설치 Sliicon apple Mac (M1) Mysql 설치 얼마전까지 인텔 맥북프로를 사용하다가, M1 이 그렇게 좋다기에 큰 마음 먹고, 장비교체를 하게 되었다. ( M1 사용기 리뷰는 아니니, 자세한 내용은 적지 않겠지만, 확실히 OS 와 하드웨어의 호환성은 좋아진 것 같다. ) 그래서 다시한번 개발환경을 세팅하게 되었고, 관련 세팅방법에 대해 기록해두려고 이렇게 글을 쓰게 되었다. 최초에 M1 칩이 나왔을때, 호환성 문제(지원이안되는 SW)들이 많아서, 사용하기 꺼려졌었는데, 이제는 Homebrew 나, 많은 SW들을 지원하기 시작하고, 이미 지원되었기때문에, 갈수록 환경은 더 나아질 것이라 보여진다. 기본적으로 Homebrew 3.0 부터 M1칩에 대한 지원이 시작했기때문에, 기존과 동일하게 Mys.. 더보기
[DATABASE] ORACLE 데이터 복구하기 [DATABASE] ORACLE 데이터 복구하기 테이블 복구 데이터베이스를 통해 데이터를 관리할때 가끔 실수를 할 수 있습니다. UDPATE 에 WHERE 절을 안붙여서 전체 업데이트가 되었다던지, 지우지 말아야할 데이터를 삭제하였다던지 당황스럽지만 차근차근히 해결해봅시다. 1. 복구하고 싶은 테이블 데이터를 확인 - [ INTERVAL '10' ]분은 10분뿐만 아니라, 원하는 시간을 입력하여 원하는 시간전의 데이터를 조회 할 수 있다. SELECT * FROM TABLE_NM AS OF TIMESTAMP(SYSTIMESTAMP-INTERVAL '10' MINUTE); 2. 테이블 백업 ( 생성 - 복사 ) - 복구하기에 앞서 백업 을 생활화 한다. CREATE TABLE TABLE_NM_BACK AS.. 더보기
[DATABASE] ORACLE 테이블간 데이터 복사 [DATABASE] ORACLE 테이블간 데이터 복사 테이블간의 데이터를 복사, 가져와야 하는 경우가 생길 수 가 있습니다. 이때, 아래의 쿼리로 해결할 수 있습니다. TO 테이블 : 빨간색 FROM 테이블 : 파란색 1. 테이블 복사하기 스키마 & 데이터 CREATE TABLE [테이블] AS SELECT * FROM [테이블] [WHERE 절] 2. 테이블 구조만 복사하기 CREATE TABLE [테이블] AS SELECT * FROM [테이블] WHERE 1=2 [where절에 '참'이 아닌 조건을 넣어줌] 3. 테이블은 이미 생성되어 있고 데이터만 복사 (테이블 구조가 동일할 때) INSERT INTO [테이블] SELECT * FROM [테이블] [WHERE 절] 4. 테이블은 이미 생성되어 있.. 더보기
[ DATABASE ] Oracle 설치 - 오라클 11g 설치하기 [ DATABASE ] Oracle 설치 - 오라클 11g[ DATABASE ] Oracle 설치 - 오라클 11g 설치하기 먼저, 설치 파일을 오라클 홈페이지에서 다운받도록합니다. https://www.oracle.com/technetwork/database/enterprise-edition/downloads/index.html Oracle Database Software Downloads | Oracle Technology Network | Oracle Thank you for accepting the OTN License Agreement; you may now download this software. Oracle Database 19c (19.3) Oracle Database 18c (18.4).. 더보기
[DATABASE] NOSQL - mongodb 설치하기 [DATABASE] NOSQL - mongodb 설치하기 # yum install mongodb mongodb-server 으로 설치를 하여도 되고, 사용자에게 맞는 mongodb 버전을 설치하려면 아래의 repositoty 에 적용하여 설치하도록 합니다. # vi /etc/yum repos.d/mongodb.repo # yum install -y mongodb-org #mongo 더보기
[DATABASE] Mysql 설치부터 환경설정까지 [DATABASE] Mysql 설치부터 환경설정까지 MSSQL 이나 오라클 등의 다양한 Database가 존재하지만, 무료로 가볍게 사용하기엔 Mysql 만한게 없다고 생각합니다. 많은 분들이 Mysql 에 대해 알고 계시기때문에 설치 방법만 포스팅하도록 하겠습니다. MYSQL ( https://ko.wikipedia.org/wiki/MySQL ) ySQL(마이에스큐엘, /maɪ ˌɛskjuːˈɛl/)[1]은 세계에서 가장 많이 쓰이는[2] 오픈 소스의 관계형 데이터베이스 관리 시스템(RDBMS)이다.[3] 다중 스레드, 다중 사용자 형식의 구조질의어 형식의 데이터베이스 관리 시스템으로서 MySQL AB가 관리 및 지원하고 있으며, Qt처럼 이중 라이선스가 적용된다. 하나의 옵션은 GPL이며, GPL 이.. 더보기
[DATABASE/MYSQL] MySQL 인바운드 허용하기 - 외부로 부터의 접속 포트 허용하기 [DATABASE/MYSQL] MySQL 인바운드 허용하기 - 외부로 부터의 접속 포트 허용하기 이번에 알아볼 내용은 Mysql 3306 포트에만 국한된 Tip 이 아니라, 여러 외부로 부터의 접속 포트 허용에 기본이 되는 인바운드 규칙을 설정해주는 일입니다. 목적은 ' 내 PC에, 내가 허용한 포트로의 접속을 허용한다' 라는 점입니다. 즉, 인바운드 규칙이란 것은 '내 PC로 들어오는 규칙' 에 대한 설정을 하는 것입니다. 간단하지만, 굉장히 유용하고, 자주 쓸수 있는 TIP 이지요. 1 ) 제어판 > 방화벽 설정 2 ) 고급 설정 > 인바운드 규칙 > 새 규칙 3 ) TCP / UDP 에 대한 선택을 하고, 특정 포트에 대한 설정을 해줍시다. 현 예제는 Mysql 인바운드 정책을 변경하는 방법이니 3.. 더보기
[DATABASE/MYSQL] Host '192.168.0.111' is not allowed to connect to this MySQL server 에러 - DB 원격 접속 권한 [DATABASE/MYSQL] Host '192.168.0.111' is not allowed to connect to this - MySQL server 에러 DB 원격 접속 권한 위의 에러는 로컬 DB가 아닌, 원격지의 DB 에 접속을 하려 할때, 해당 DB에 대한 접근 권한이 없기때문에 발생하는 에러입니다. 그렇기 때문에, 원격지의 DB 에서 접속하는 IP 에 따른 접속 권한을 주어서 이 문제를 해결해 보도록 합시다. 1 ) ROOT 계정으로 MYSQL 접속 > mysql -u root -p 2) 접속 허용 IP에 대한 권한을 부여합니다. > GRANT ALL PRIVILEGES ON *.* TO root@'[IP]' IDENTIFIED BY '[PASSWORD]'' WITH GRANT OPTION.. 더보기
[DATABASE] Mysql SELECT 존재 여부 체크 [DATABASE] Mysql SELECT 존재 체크 생각보다 SELCT 결과값이 존재하는지 안하는지에 대한 Boolean 값이 필요한 경우가 많이 있는데, SELECT EXISTS 문을 통해 결과 값의 존재 여부를 확인 할 수 있다. SELECT EXISTS ( ) as isChk // 결과값이 존재하면 1 // 결과값이 존재하지 않으면 0 더보기
[DATABASE] Mysql UPDATE SELECT - 결과에 특정한 컬럼 값 업데이트 [DATABASE] Mysql UPDATE SELECT - 결과에 특정한 컬럼 값 업데이트 Sub쿼리를 이용하여 SELECT 한 값에 대해 업데이트하는 것도 가능하지만, 2개이상의 결과가 나올 경우, 복잡한 쿼리 짜기가 필요 없이 단순한 조건이라면, 아래의 방법으로 바로 업데이트하는 것이 가능. UPDATE TABLE A INNER JOIN TABLE B ON A.key = B.key SET A.(업데이트할 컬럼) = (업데이트값) WHERE 조건문 1 AND 조건문 2 (예시_) UPDATE TABLE A INNER JOIN TABLE B ON A.key = B.key SET A.col = 'c' WHERE B.col < CURDATE() AND A.col2 = '2' 더보기