본문 바로가기

DB 수업 정리

DB 3일차

test2 테이블에서 확인

1. score 칼럼을 추가 기본값을 0으로 설정

alter table test2 add score int default 0;

2. 학과가 kor 학생들을 출력

select * from test2 
where dep = 'kor';


3. 학과가 com인 튜플을 kor로 변경 

update test2
set dep = 'kor'
where dep = 'com';

4. score의 값을 update

update test2
set score = 70
where num = 111;
update test2
set score = 84
where num = 222;
update test2
set score = 47
where num = 333;
update test2
set score = 97
where num = 444;
update test2
set score = 88
where num = 555;

5. score가 80이상인 학생들만 출력

select * from test2
where score >= 80;

6. 학과별 인원수 출력 (학과별로 오름차순)

select dep, count(dep) '학과별 인원수' from test2
group by dep
order by dep;

7. 학과별 성적 평균 (소수점 2자리 반올림) 칼럼명 평균

select dep, round(avg(score),2) '평균' from test2
group by dep;

8. 주소별 인원수 출력 (주소별로 오름차순)

select addr, count(addr) '주소별 인원수' from test2
group by addr
order by addr;

9. 컴퓨터 학과만 성적 합계 출력

컴퓨터학과가 없어서 수정

update test2
set dep ='com'
where num = 111;

update test2
set dep ='com'
where num = 444;

select dep ,sum(score) '컴퓨터 학과 성적 합계' from test2
where dep = 'com';

select dep, sum(score) from test2
group by dep
having dep = 'com';

10. 성적이 70점이상인 학생들의 num,name,dep,score만 출력

select num,name,dep,score from test2
where score >=70;



-----------------------------------------------------------

- 제품 테이블 (product)

create table product(
num int auto_increment,
type_a varchar(50) not null,
type_b varchar(50) not null,
name varchar(100) not null,
price int default 0,
amount int default 100,
sale_amount int default 0,
register_date datetime,
primary key (num));

insert into product(type_a, type_b, name, price, amount, sale_amount, register_date) values
('티셔츠','긴소매','폴라 티셔츠',15000,34,100,'2023-10-15'),
('티셔츠','긴소매','크롭 티셔츠',10000,50,100,'2023-10-15'),
('티셔츠','반소매','순면라운드 반팔티',15900,10,153,'2023-09-15'),
('티셔츠','민소매','에이 나시',9000,33,33,'2023-09-10'),
('패션운동복','트레이닝상의','피트니스상의',30000,34,55,'2023-12-05'),
('패션운동복','트레이닝하의','피트니스하의',50000,55,34,'2023-12-06'),
('패션운동복','트레이닝세트','피트니스상하의',90000,70,34,'2023-12-07'),
('아우터','재킷','양면 롱 후리스 자켓',23300,100,42,'2023-11-05'),
('아우터','코트','양털 겨울 코트',50000,50,30,'2023-10-31'),
('아우터','코트','트렌치 코트',40000,50,30,'2023-10-31'),
('아우터','패딩','롱 패팅 점퍼',47400,10,45,'2023-11-01');


- 판매 테이블 (buy)

create table buy(
num int auto_increment,
customer varchar(20) not null,
product_name varchar(100) not null,
price int default 0,
amount int default 0,
buy_date datetime default now(),
primary key (num));


-----------------------------------------------------------------------

- 홍길동이 폴라 티셔츠 5개를 구매

insert into buy(customer,product_name,price,amount)
values('홍길동','폴라 티셔츠',15000,5);


- product 테이블에서 제품내용을 조회하여 추가

- 홍길순이 크롭 티셔츠를 3장 구매 (num =2)

insert into buy(customer,product_name,price,amount)
select '홍길순', name, price, 3 from product
where num = 2;


- 5명이 여러가지 상품으로 구매

insert into buy(customer,product_name,price,amount)
select '김현우', name, price, 2 from product
where num = 10;

insert into buy(customer,product_name,price,amount)
select '유성혁', name, price, 8 from product
where num = 5;

insert into buy(customer,product_name,price,amount)
select '이승재', name, price, 5 from product
where num = 7;

insert into buy(customer,product_name,price,amount)
select '이지안', name, price, 1 from product
where num = 11;

insert into buy(customer,product_name,price,amount)
select '한희준', name, price, 6 from product
where num = 4;

- 제품별 판매 수량 조회

select product_name, sum(amount) '제품별 판매 수량' from buy
group by product_name;


- 제품별 판매 금액 조회

select product_name, sum(price) '제품별 판매 금액' from buy
group by product_name;


- total 필드를 추가 int 

alter table buy add total int after amount;

- price*amount 곱한 값으로 나타내기

update buy
set total = price*amount;

- 칼럼을 생성시 계산된 값을 자동계산하며 생성
(generated columns)
- stored : 값이 저장되는 방식
 => 데이터가 입력되거나 수정될 때 해당 칼럼도 같이 갱신

- virtual : 데이터를 저장하지 않고 정의만
 => 해당 칼럼을 읽으려고 시도할 때 계산을 통해 보여주는 것만 

- 방금전 생성한 total 필드를 삭제하고, 다시 generated columns으로 다시추가

alter table buy drop total;

alter table buy add total int generated always as 
(price*amount) stored after amount; 


- 전체 총 판매수량과 총 매출액 출력

select sum(amount) ' 총 판매수량 ' , sum(total) ' 총 매출액 ' from buy;

----------------------------------------------------------------

- product 테이블에서

1. 최신 상품순으로 정렬

select * from product order by register_date desc;

2. type_a 별로 상품의 개수와 price 합계

select type_a , count(type_a) , sum(price) from product
group by type_a;

3. price 20000이상인 제품은 할인상품에 해당 할인상품을 출력

select name as '할인상품' from product
where price >= 20000;


4. 할인상품의 이름과 가격을 출력
-- 할인가격(2만원 이상인 제품만 대상으로 10% 할인된 가격)
-- 할인상품명, 정상가, 할인가

select name as '할인상품명' , price as '정상가' , round((price*0.9),0) as ' 할인가' from product
where price >= 20000;

- 모든데이터의 이름, 정상가, 할인가 출력
(할인대상 상품이 아니라면 할인가 = 정상가)

select name, price '정상가', if( price >= 50000 ,  round((price*0.9),0) , price) as '할인가' from product;

5. 11월에 입력된 상품만 출력

select * from product
where register_date like '%11%';

select * from product
where month(register_date) =11;


=> date_format : %y(년도 2자리) %Y(년도 4자리)

select date_format(register_date, '%y-%m') as mon from product; 


- 월별 판매수량 (sale_amount) 합계

select month(register_date) as 'month', sum(sale_amount) '총 판매수량' from product
group by month
order by month;

select date_format(register_date, '%y-%m') as 'month', sum(sale_amount) '총 판매수량' from product
group by month
order by month;


6. type_a 별로 판매량의 합계가 가장큰 값을 출력

select type_a , sum(sale_amount) from product
group by type_a
order by sum(sale_amount) desc limit 0,1;

- 서브쿼리 사용 ( 서브쿼리의 값을 이용할 경우 별칭은 필수)

select max(sum) from
(select sum(sale_amount) as sum from product
group by type_a) p;

---------------------------------------------------------------------------------

트랜잭션 (transaction)

- 하나의 작업을 하기 위한 명령어 묶음 단위
- 하나의 트랜잭션에서 실행하는 모든 명령어가 완료되어야 전체가 완료되는 형태의 작업에서 사용
- 만약 하나라도 작업이 취소되면 모두 취소
- 완료와 취소를 나중에 결정하는 개념
- 임시 실행 개념
- 데이터의 안전성을 확보하기 위한 방법

start transaction;
명령어1;
명령어2;
...
commit;  => 완료
rollback;  => 취소

DDL ( create, drop, alter, rename) => rollback 대상이 아님

- mysql 에서는 auto commit 이 기본적으로 on 상태

트랜젝션을 이용하여

1. 폴라 티셔츠 가격을 15000 => 17000 변경
start transaction;
update buy
set price = 17000
where num = 1;

2. 변경된 값을 확인
select * from buy;
rollback;

-------------------------------------------------------------

1. buy 테이블에서 customer의 이름을 홍0동 변경하여 출력 (select)

select num, insert(customer,2,1,'0') as customer, product_name, price, amount ,total , buy_date from buy;


2. product 테이블에서 price가 40000이상인 데이터만 상품명(할인상품) 표시하여 출력 (전체데이터 표시)

select num, type_a, type_b, if(price>=40000, concat(name, '(할인)'), name) as name , price, amount,sale_amount, register_date
 from product;

3. product 테이블에서 월별 매출(price*sale_amount) 합계 출력

select month(register_date) as 'month' , sum( price*sale_amount) from product
group by month
order by month;

4. product 테이블에서 price가 가장 큰 (가장비싼) 제품명, price 출력

select name , price from product
order by price desc limit 0,1;

5. buy 테이블의 구매내역을 3개 추가 
=> (product 테이블 조회하여 추가)

insert into buy(customer,product_name,price,amount)
select '이영한', name, price, 5 from product
where num = 4;
insert into buy(customer,product_name,price,amount)
select '이제동', name, price, 3 from product
where num = 5;
insert into buy(customer,product_name,price,amount)
select '김택용', name, price, 4 from product
where num = 8;


6. product_non 테이블을 product 테이블과 같은 형식으로 추가하여
   register_date의 9월 데이터를 이동
   => 기존 product 테이블에서 제거
   => transaction을 이용하여 첫 과정부터 완료되었을 때 commit하기.

create table if not exists product_non like product;
start transaction;

insert into product_non 
(select * from product
where month(register_date) =9);

delete from product
where month(register_date) =9;

commit;

7. buy 테이블에서 가장 많이 판매한 제품의 이름을 출력

select product_name as '가장 많이 판매한 제품' , sum(amount) ' 판매량 ' from buy
group by product_name
order by sum(amount) desc limit 1;

select product_name from buy
group by product_name
having sum(amount) = (
select max(total_sum) from
(select sum(amount) as total_sum from buy
group by product_name) as p);


 

ERD 

E - R 다이어그램

 

 

 

DB 생성 - root 계정에서 생성

mysqlUser => 생성한 DB를 사용할 수 있는 권한 부여

DB명 => school (student,attend,course 테이블 생성)

1. root 계정으로 접속


2. create database school; => db 생성


3. mysqlUser 권한부여 => 권한 확정

grant all privileges on school.* to 'mysqlUser'@'localhost' with grant option;


4. mysqlUser 계정으로 접속


5. 테이블 3개생성

 

create table student(
std_num varchar(10),
std_name varchar(20) not null,
std_major varchar(20),
std_term int,
std_point int,
primary key (std_num));

create table course(
co_code varchar(10),
co_name varchar(20) not null,
co_professor varchar(20),
co_point int default 3,
co_time int,
co_timetable varchar(40),
primary key (co_code));

create table attend(
at_num int auto_increment,
at_std_num varchar(10),
at_co_code varchar(10),
at_year int,
at_term int,
at_mid int default 0,
at_final int default 0,
at_attend int default 0,
at_hw int default 0,
at_repetition varchar(1) default 'n',
at_score varchar(4),
primary key (at_num));


6. 외래키지정

alter table attend add foreign key(at_std_num)
references student(std_num);

alter table attend add foreign key(at_co_code)
references course(co_code); 

 

-- school 데이터

insert into student values
('2019160123','전봉준','컴퓨터공학과',2,64),
('2019456001','강길동','디자인',3,60),
('2020123001','강나래','화학공학',1,56),
('2020123020','박철수','화학공학',1,57),
('2020160001','강철수','컴퓨터공학',1,40),
('2020160002','나영희','컴퓨터공학',1,60),
('2022123001','강다운','화학공학',1,45),
('2022123002','김수진','디자인',1,50),
('2023160001','이영철','컴퓨터공학',1,55),
('2023160002','최수지','디자인',1,65);


insert into course values
('2020ipc001','컴퓨터개론','유관순',2,2,'화1A,1B,2A,2B'),
('2020ipc002','기초전기','이순신',3,4,'월1A,1B,2A목1A,1B,2A'),
('2020msc001','대학수학기초','홍길동',3,3,'월1A,1B,2A수1A,1B,2A'),
('2020msc002','프로그래밍일반','임꺽정',3,3,'월1A,1B,2A목1A,1B,2A'),
('2021deg001','디자인기초','황희',2,3,'목1A,1B,2A,2B'),
('2021deg002','색채이론','신사임당',3,2,'금1A,1B,2A,2B'),
('2022che001','화학이론','김길동',3,2,'월1A,1B,수2A,2B');


insert into attend(at_std_num, at_co_code) values
('2020160001','2020msc001'),
('2020160002','2020msc001'),
('2023160002','2021deg001'),
('2023160002','2021deg002'),
('2019160123','2020msc002'),
('2019456001','2020msc002'),
('2020123001','2020ipc001'),
('2020123020','2020ipc001'),
('2020123020','2022che001'),
('2020123001','2022che001'),
('2019456001','2020ipc002'),
('2019160123','2020ipc002'),
('2022123001','2020msc002'),
('2020160002','2020msc002'),
('2019160123','2020msc001'),
('2019456001','2020msc001'),
('2023160002','2022che001'),
('2022123001','2022che001'),
('2023160001','2020msc002'),
('2022123002','2021deg001'),
('2022123002','2021deg002'),
('2023160002','2020msc002');

'DB 수업 정리' 카테고리의 다른 글

DB 5일차.  (3) 2024.09.02
DB 4일차  (0) 2024.08.30
DB 2일차  (0) 2024.08.28
DB 1일차  (5) 2024.08.27
mysql 설치 & 설정  (0) 2024.08.26