장래쌤과 함께하는 쉽고 재미있는 파이썬 이야기
₩39,600
입문 / Python, 객체지향
5.0
(2)
전문 강사에게서 배우는 쉽고 재미있는 파이썬 이야기! 처음 배우는 분들을 위해 차근차근 강의를 진행합니다. 충분히 반복하며 학습할 수 있는 기회를 제공합니다.처음 파이썬을 배우는 분들에게 든든한 디딤돌이 될 것입니다.
입문
Python, 객체지향
현) 디프렌즈 대표
현) 마이크로소프트 공인 강사
전) 마이크로소프트 데이터플랫폼 MVP
전) 씨퀄로 수석 컨설턴트
전) 웹타임교육센터 전임강사
전) 푸르덴셜생명보험 정보시스템 책임
[강의분야]
데이터베이스 개발자, 운영자 과정
데이터베이스 쿼리 튜닝 및 최적화 과정
파이썬, 데이터 전처리, 시각화 과정
파이썬 기반 데이터 분석, 머신러닝 과정
[저서]
디비로 누리는 특별한 세상, SQL Server 개발편
디비로 누리는 특별한 세상, SQL Server 운영편
이장래와 함께하는 SQL Server 운영과 개발 등
장래쌤과 함께하는 쉽고 재미있는 파이썬 이야기
₩39,600
입문 / Python, 객체지향
5.0
(2)
전문 강사에게서 배우는 쉽고 재미있는 파이썬 이야기! 처음 배우는 분들을 위해 차근차근 강의를 진행합니다. 충분히 반복하며 학습할 수 있는 기회를 제공합니다.처음 파이썬을 배우는 분들에게 든든한 디딤돌이 될 것입니다.
입문
Python, 객체지향
장래쌤과 함께하는 쉽고 재미있는 SQL Server 운영 이야기(기본편)
₩74,800
입문 / MSSQL, DBMS/RDBMS
5.0
(5)
마이크로소프트 공인 강사에서 배우는 쉽고 재미있는 SQL Server 운영 이야기! 배워서 바로 쓸 수 있는, 현장에서 정말 필요한 핵심 운영 기술을 초보자도 쉽게 이해할 수 있도록 차근차근 설명합니다.
입문
MSSQL, DBMS/RDBMS
장래쌤과 함께하는 쉽고 재미있는 SQL 이야기
₩49,500
입문 / SQL, DBMS/RDBMS, MySQL, Oracle, MSSQL
4.8
(10)
전문 강사에게서 배우는 쉽고 재미있는 SQL 이야기! 초보자를 위해 체계적으로 차근차근 강의를 진행합니다. 3단계 학습 과정을 통해 충분히 반복하며 학습할 수 있는 기회를 제공합니다.
입문
SQL, DBMS/RDBMS, MySQL
질문&답변
create view
안녕하세요?뷰를 만들 때는 0 row affected 로 출력이 됩니다.실제 영향을 받은 테이블 행이 없다는 의미의 정상정인 문구입니다.뷰를 만든 다음에 다음과 깉이 뷰를 조회하면 뷰에 정의된 쿼리문이 수행되면서 데이터가 표시됩니다.SELECT * FROM employee_infomation2;확인해 보시고, 다른 문제가 있으면 다시 질문해 주시기 바랍니다.감사합니다.
질문&답변
json 배열 파싱
안녕하세요?올려주신 형태의 데이터는 배열 형태의 JSON 문자열이 아닙니다. 다음과 같은 형태가 되어야 합니다.{ "fruit": [{"name": "사과", "price": 2000}, {"name": "배", "price": 2000}], "food": [{"name": "햄버거", "price": 7500}] }그래야 여러 과일을 반복해 읽어올 수 있습니다.그리고 제가 경험한 바로는 MySQL에서는 JSON의 속성 이름이 한글이 되면 오류가 발생합니다. 그래서 위와 같이 영문으로 이름을 주는 것이 좋습니다. 제대로 된 JSON 형태라면 JSON 관련 함수를 사용해 조회할 수 있습니다. 우선 쉽게 조회할 수 있는 형태로 테이터를 전달 받을 수 있는 방법을 고민해 보시면 좋을 것 같습니다.우선 다음 예제 코드를 참고하시기 바랍니다.-- 테이블 만들기 CREATE TABLE Sample ( id INT AUTO_INCREMENT PRIMARY KEY, json_data JSON ); -- 데이터 추가 INSERT INTO Sample (json_data) VALUES (' { "fruit": [{"name": "사과", "price": 2000}, {"name": "배", "price": 2000}], "food": [{"name": "햄버거", "price": 7500}] } '); -- 추출 SELECT 이름, 가격 FROM ( SELECT jt.이름, jt.가격 FROM sample, JSON_TABLE(json_data, '$.fruit[*]' COLUMNS (이름 VARCHAR(100) PATH '$.name', 가격 INT PATH '$.price')) jt UNION ALL SELECT jt.이름, jt.가격 FROM sample, JSON_TABLE(json_data, '$.food[*]' COLUMNS (이름 VARCHAR(100) PATH '$.name', 가격 INT PATH '$.price')) jt ) AS combined; -- 결과 /* 이름 가격 ------------- 사과 2000 배 2000 햄버거 7500 */감사합니다.
질문&답변
insert into 구문
안녕하세요?캡쳐해서 보여주시는 구문에는 문제가 없어 보입니다. 그리고 하단의 결과는 보여주신 구문의 결과라고 보기 힘듭니다.예전에 작성한 구문의 결과인 것 같아요. 위 구문, 즉 retired_employee 테이블 삭제 구문부터 하나씩 다시 실행해 보시면 좋을 것 같습니다. 그래도 안되시면 다시 질문해 주세요. 그리고 예전 질문에 대한 답변을 했는데 해결 여부가 체크되지 않았네요. 제 답변으로 문제가 해결되었으면 질문 상태를 바꿔주시면 감사하겠습니다. 감사합니다.
질문&답변
PDF 자료 문의
안녕하세요?PPT가 강의 진행용으로 준비가 된 것이라 따로 공부하기에 충분한 내용이 아닙니다. 그래도 혹시 필요하시다면 jangrae@gmail.com으로 메일 보시면 보내드릴게요. 강의 내용 중에 궁금한 것 있으면 언제든 문의해 주시기 바랍니다.문의해 주셔서 감사합니다~
질문&답변
집계 연산자에 대한 질문
안녕하세요?and와 or는 where절에서 여러 조건을 연결할 때 사용합니다. select절에서는 보고싶은 것을 콤마로 구분해 나열하면 됩니다. 이것은 정해진 구문 규칙이므로 꼭 따라야 합니다.이해 안되는 부분 있으면 다시 질문해 주세요.질문해주셔서 감사합니다.
질문&답변
array_agg 배열 해제
안녕하세요?콤마로 구문된 값을 갖는 데이터에서 값들을 분리하는 방법을 문의한 것으로 이해했습니다.아쉽게도 MySQL에는 이러한 기능을 갖는 함수가 아직 없습니다.다른 DBMS에서는 쉽게 할 수 있는데, MySQL은 그렇지 않습니다.이 기능을 구현하는 몇 가지 방법이 있는데,그 중에서 JSON_TABLE을 사용하는 방법으로 예제를 만들어봤습니다.아래 내용을 참고하시면 좋겠습니다.-- 데이터 만들기 DROP TABLE IF EXISTS T1; CREATE TABLE T1 ( col1 int, col2 varchar(100) ); INSERT INTO T1 VALUES (1, 'A,B,C,D,E,F,G'); -- 추출하기 SELECT js.value AS splited FROM t1, JSON_TABLE(CONCAT('["', REPLACE(t1.col2, ',', '","'), '"]'), "$[*]" COLUMNS (value VARCHAR(10) PATH "$")) AS js; /* splited -------- A B C D E F G */질문해 주셔서 감사합니다.
질문&답변
null 수강 관련 문의
안녕하세요?NULL 값은 IS NULL, IS NOT NULL로 비교하지만, 일반적인 값을 비교할 때는 IS 가 아닌 = 연산자를 사용해야 합니다. 그러므로 다음과 같이 gender = 'F' 형태로 수정해야 합니다.SELECT emp_name, emp_id, gender, dept_id, hire_date, COALESCE(salary, 0) AS salary FROM employee WHERE retire_date IS NULL AND gender = 'F';질문해 주셔서 감사합니다~
질문&답변
테이블 생성 후 조건 수정 방법
안녕하세요?우선 테이블은 물리적으로 데이터를 가지고 있는 존재입니다. 이 테이블의 데이터를 수정하려면 UPDATE 문, 추가하려면 INSERT 문, 삭제하려면 DELETE 문을 사용합니다. 물론 조회할 때는 SELECT 문을 사용합니다. 뷰는 데이터를 가지고 있지 않습니다. 뷰를 만들 때 포함된 쿼리문을 가지고 있으며, 뷰가 SELECT 문으로 조회될 때 그 쿼리가 수행되어 테이블에서 데이터를 가져와 보여주는 것입니다. 그러므로 뷰는 항상 최신 데이터를 보여주게 됩니다. 테이블과 뷰는 SELECT 대상이 된다는 것은 같지만, 테이블은 물리적으로 데이터를 가지고 있고, 뷰는 데이터가 아닌 쿼리문을 가지고 있다는 것이 가장 큰 차이입니다. 예를 들어, 직원 테이블에 직원 정보가 있는데, 이 직원 정보 중에서 퇴사한 직원만 조회하고 싶다고 가정해 봐요. 그럼 퇴사자를 조회하는 SELECT 문을 작성해야 하겠죠? 이 상황에서 퇴사자를 조회하는 SELECT 문을 뷰로 정의한다면, 이후 부터는 그 뷰만 조회하면 퇴사자 정보를 조회할 수 있습니다. 뷰를 조회할 때마다 퇴사자를 조회하는 SELECT 문이 수행되어, 테이블에서 퇴사자 정보만 가져와 보여줄 것이기 때문입니다. 이해가 되셨으면 좋겠네요. 즐거운 추석 연휴 보내시길 바랍니다~
질문&답변
주차별 데이터에서 전 주 데이터 가져오기
안녕하세요?우선, 상당히 많은 쿼리문을 질문하시는 데, 어떤 상황에서의 질문인지 궁금합니다.혹시 제가 질문하시는 분이 더 깊이 생각해 볼 기회를 빼앗는 것은 아닌지,너무 쉽게 답을 찾게 하는 것은 아닌지 염려가 됩니다.제 강의의 일부만 보신 것 같아 더욱 염려가 됩니다. 질문하신 내용에 대해 제가 이해하는 수준에서 예제를 만들어 봤습니다.오늘의 주차에서 1을 뺀 주차를 갖는 행을 찾는 WHERE 절을 사용했습니다.아래 내용을 참고하시기 바랍니다.DROP TABLE IF EXISTS test; -- 테이블 만들기 CREATE TABLE test ( week int, date date, val char(1) ); -- 데이터 추가 INSERT INTO test VALUES(32, '2024-08-08', 'A'), (32, '2024-08-09', 'A'), (33, '2024-08-12', 'B'), (33, '2024-08-13', 'C'); -- 조회 SELECT * FROM test WHERE WEEK(date) = WEEK(CURRENT_DATE) - 1; /* week date val ------------------- 32 2024-08-08 A 32 2024-08-09 A */감사합니다.
질문&답변
여러 컬럼 중 null값이 아닌 값 가져오기
안녕하세요?질문해 주셔서 감사합니다~간단하게 아래와 같이 예제를 만들어 봤습니다.COALESCE() 함수를 사용하면 됩니다.참고하시기 바랍니다.-- 테이블 만들기 CREATE TABLE Test ( name varchar(10), val01 int, val02 int, val03 int, val04 int, val05 int, val06 int, val07 int, val08 int, val09 int ); -- 데이터 추가 INSERT INTO Test VALUES('A', 10, 20, 30, NULL, 50, NULL, NULL, NULL, 90); -- 조회 SELECT name, val01, COALESCE(val02, val01) AS val02, COALESCE(val03, val02, val01) AS val03, COALESCE(val04, val03, val02, val01) AS val04, COALESCE(val05, val04, val03, val02, val01) AS val05, COALESCE(val06, val05, val04, val03, val02, val01) AS val06, COALESCE(val07, val06, val05, val04, val03, val02, val01) AS val07, COALESCE(val08, val07, val06, val05, val04, val03, val02, val01) AS val08, COALESCE(val09, val08, val07, val06, val05, val04, val03, val02, val01) AS val09 FROM Test; /* name val01 val02 val03 val04 val05 val06 val07 val08 val09 ----------------------------------------------------------------------------- A 10 20 30 30 50 50 50 50 90 */감사합니다~