티스토리 뷰
1. 리눅스 설치
1) 리눅스에 mysql 설치
# 패키지 리스트 업데이트
sudo apt update
# mysql 서버 설치
sudo apt install mysql-server
# mysql 상태 확인
sudo systemctl status mysql
# mysql 보안 설정
sudo mysql_secure_installation
# mysql 접속
sudo mysql
# root 계정/비밀번호 설정
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '비밀번호';
FLUSH PRIVILEGES;
# 로그인
mysql -u root -p
2) 윈도우 vscode에서 ubuntu에 설치된 mysql 접속하기
- WSL2는 가상 네트워크로 동작해서, MySQL을 그냥 localhost로는 접속이 안된다
- WSL2 MySQL을 외부(IP)에서 접속가능하게 만들거나 Windows에서 WSL2 포트로 접속을 포워딩
# 리눅스 ip 조회하기(Ubuntu)
hostname -I
# 윈도우 CMD 관리자권한으로 열기(localhost:3306으로 접속시 리눅스로 보내줌, 포트포워딩)
netsh interface portproxy add v4tov4 listenport=3306 listenaddress=127.0.0.1 connectport=3306 connectaddress=<WSL IP>
# 포트포워딩 삭제하려면
netsh interface portproxy delete v4tov4 listenport=3306 listenaddress=127.0.0.1
# windows 방화벽에 예외 규칙 추가
netsh advfirewall firewall add rule name="MySQL Port 3306" dir=in action=allow protocol=TCP localport=3306
2. SQL 작성 규칙
- SQL 문법은 대문자로, 테이블명과 속성명은 소문자로 작성하는 것을 권장
- 이름은 항상 의미가 잘 드러나도록 작성하고, 여러 단어를 혼합할 경우 '_'를 사용한다
- 주석은 '--'
- 명령어 끝에는 세미콜론(;)을 작성
3. 데이터베이스 언어 구분
- 정의어 DDL: 테이블과 같은 데이터 구조 정의
- 조작어: 데이터 조회 및 검색
- 제어어: 데이터베이스에 접근하는 권한 관리
4. 데이터베이스 조회/생성
-- 데이터베이스 조회
SHOW DATABASES;
-- 데이터베이스 생성
CREATE DATABASE my_db;
-- 해당 데이터베이스로 접속
USE my_db;
5. 데이터베이스의 테이블 조회(조작)/생성(정의)
-- 테이블 목록 확인
SHOW TABLES;
-- 테이블 생성
CREATE TABLE customer(
id VARCHAR(10) NOT NULL, # NULL: 비어 있는 값
name VARCHAR(10) NOT NULL,
address VARCHAR(30) NULL
);
-- 테이블 구조 확인
DESC customer;

1) 자료형
- VARCHAR(N): nBytes 크기의 가변 길이 문자열 데이터
- INT : 정수형 숫자 데이터(4Bytes)
- FLOAT: 4Bytes 크기의 부동 소수점 데이터
- DATETIME: 날짜와 시간 형태의 기간 데이터(YYYY-MM-DD HH:MM:SS)
2) 테이블 이름 수정/삭제
-- 컬럼 추가(alter table 테이블명 add column 컬럼명 데이터타입 제약조건)
ALTER TABLE customer ADD COLUMN birthday DATE NULL;
-- 컬럼 수정(alter table 테이블명 modify column 컬럼명 데이터타입 제약조건)
ALTER TABLE customer MODIFY COLUMN id varchar(15) NULL;
-- 컬럼 이름 변경(alter table 테이블명 change column 기존컬럼명 새로운컬럼명 데이터타입 제약조건)
ALTER TABLE customer CHANGE COLUMN name korean_name VARCHAR(10) NOT NULL;
-- 컬럼 삭제(alter table 테이블명 drop column 컬럼명)
ALTER TABLE customer DROP COLUMN address;
-- 테이블 이름 변경(alter table 테이블명 rename 새로운테이블명)
ALTER TABLE customer RENAME member;
-- 테이블 삭제(drop table 테이블명)
DROP TABLE member;
-- 테이블 조회(desc 테이블명)
DESC member;
* NOT NULL: Null을 비허용, 공백('')은 가능
6. 데이터 삽입/조회
insert into customer(id, name, address) values(1,'홍길동','서울시 송파구');
-- 모든 속성을 순서대로 입력하는 경우 속성 목록은 생략 가능하다
insert into customer values(2,'김철수', '서울시 강남구');
select * from customer
반응형
'AI > SQL' 카테고리의 다른 글
[SQL] 이상 현상과 정규화 (0) | 2025.04.09 |
---|---|
[SQL] 제약조건, 키(Key), 인덱스 (0) | 2025.04.08 |
[SQL] 데이터와 정보 (0) | 2025.04.07 |
[SQL] UPSERT (0) | 2025.02.24 |
[SQL] MySQL 계정 생성 및 외부 접속 (0) | 2025.01.20 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- ChatGPT
- opic
- 운동
- 실기
- SQL
- llm
- 미라클모닝
- 기초
- 30분
- 뉴스
- 루틴
- 갓생
- 아침
- 오블완
- 경제
- Python
- 줄넘기
- 습관
- 오픽
- 영어회화
- 고득점 Kit
- IH
- 빅데이터 분석기사
- 스크랩
- 티스토리챌린지
- 다이어트
- Ai
- C언어
- 아침운동
- 프로그래머스
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
글 보관함