반응형

mybatis에서 mapper.xml(쿼리 작성해 놓는 xml파일)에서 파라미터를 쓸때,

2가지가 혼용되어 쓰이고 있어서 다시 한번 정리해봤습니다.

 

#{}

  • 파라미터가 String으로 들어와서(= 자동으로 '' 붙는다) 자동으로 '파라미터 '으로 적용
    • ( : where id = #{id} 이고 id 값이 1234, 쿼리에는 where id = '1234' 출력)
  • SQL Injection 예방

 

${}

  • 파라미터가 그대로 출력
  • 컬럼의 자료형에 맞춰 파라미터의 자료형이 변경
    • 사용자의 입력을 그대로 전달하는 경우에는 부적당
    • 테이블, 컬럼명을 파라미터로 전달할때 적당
  • SQL Injection 예방할 없음
반응형
반응형

문제

본문 : https://programmers.co.kr/learn/courses/30/lessons/77484

로또 6/45(이하 '로또'로 표기)는 1부터 45까지의 숫자 중 6개를 찍어서 맞히는 대표적인 복권입니다. 아래는 로또의 순위를 정하는 방식입니다. 1

순위당첨 내용

1 6개 번호가 모두 일치
2 5개 번호가 일치
3 4개 번호가 일치
4 3개 번호가 일치
5 2개 번호가 일치
6(낙첨) 그 외

로또를 구매한 민우는 당첨 번호 발표일을 학수고대하고 있었습니다. 하지만, 민우의 동생이 로또에 낙서를 하여, 일부 번호를 알아볼 수 없게 되었습니다. 당첨 번호 발표 후, 민우는 자신이 구매했던 로또로 당첨이 가능했던 최고 순위와 최저 순위를 알아보고 싶어 졌습니다.
알아볼 수 없는 번호를 0으로 표기하기로 하고, 민우가 구매한 로또 번호 6개가 44, 1, 0, 0, 31 25라고 가정해보겠습니다. 당첨 번호 6개가 31, 10, 45, 1, 6, 19라면, 당첨 가능한 최고 순위와 최저 순위의 한 예는 아래와 같습니다.

당첨 번호3110451619결과

최고 순위 번호 31 0→10 44 1 0→6 25 4개 번호 일치, 3등
최저 순위 번호 31 0→11 44 1 0→7 25 2개 번호 일치, 5등
  • 순서와 상관없이, 구매한 로또에 당첨 번호와 일치하는 번호가 있으면 맞힌 걸로 인정됩니다.
  • 알아볼 수 없는 두 개의 번호를 각각 10, 6이라고 가정하면 3등에 당첨될 수 있습니다.
    • 3등을 만드는 다른 방법들도 존재합니다. 하지만, 2등 이상으로 만드는 것은 불가능합니다.
  • 알아볼 수 없는 두 개의 번호를 각각 11, 7이라고 가정하면 5등에 당첨될 수 있습니다.
    • 5등을 만드는 다른 방법들도 존재합니다. 하지만, 6등(낙첨)으로 만드는 것은 불가능합니다.

민우가 구매한 로또 번호를 담은 배열 lottos, 당첨 번호를 담은 배열 win_nums가 매개변수로 주어집니다. 이때, 당첨 가능한 최고 순위와 최저 순위를 차례대로 배열에 담아서 return 하도록 solution 함수를 완성해주세요.

 

 

 

 

나의 풀이

class Solution {
    public int[] solution(int[] lottos, int[] win_nums) {
        int[] answer = new int[2];
        int zeroCount = 0;
        int hit = 0;
        
        for(int lotto : lottos){
            if(lotto == 0){
                zeroCount++;
            }else{
                for(int winNum : win_nums){
                    if(lotto == winNum){
                        hit++;
                        break;
                    }
                }
                
            }
        }
        
        answer[1] = 7-hit;
        answer[0] = 7-(hit+zeroCount);
        if(hit == 0) answer[1] = 6;
        if(hit+zeroCount == 0) answer[0] = 6;
        return answer;
    }
}

나의 풀이법

가장 기본적인 접근을 했다.

arrary가 2개이니까 2개의 for문을 이용해 비교하면서, 처리하는 로직을 생각했다.

후에 리팩토링은 더 필요하지만,

lotto ==0 인 경우의 처리와 break문을 통해 조금이나마 성능을 향상 시킬수 있을것이라 생각했다.

가장 지저분한게 생각한 건, 모든 로직을 끝낸후, 단순 결과 return을 위해 5줄이나 소비한것이다.

밑에 Math를 생각했더라면 그나마 만족했을듯

 

다른 사람의 풀이법

import java.util.Arrays;
import java.util.stream.LongStream;

class Solution {
    public int[] solution(int[] lottos, int[] winNums) {
        return LongStream.of(
                (lottos.length + 1) - Arrays.stream(lottos).filter(l -> Arrays.stream(winNums).anyMatch(w -> w == l) || l == 0).count(),
                (lottos.length + 1) - Arrays.stream(lottos).filter(l -> Arrays.stream(winNums).anyMatch(w -> w == l)).count()
        )
                .mapToInt(op -> (int) (op > 6 ? op - 1 : op))
                .toArray();
    }
}

 

느낀점

대체로 가장 기본적인 문제 접근 방식은 나와 비슷한 듯 하다.

다른 사람의 풀이를 보고 배울점이 있다면

  • 코드 라인을 혁신적으로 줄이는 lamda,stream 을 이용하는 경우
    가독성이 떨어지고, 심지어 성능이 떨어지는 경우도 있다 (= 짧은 코드가 항상 최선은 아닐 수 있다)
    하지만 방법을 알아두면, 또 다른 적절한 기회가 생길것
  • 2중 for문 대신 적절한 자료구조(map,set)를 이용하면 1개의 for문을 save할 수 있다
        for(int winNum : win_nums) {
            if(map.containsKey(winNum)) sameCount++;
        }
  • 기본 메소드(Math)를 이용하면, 나의 풀이 맨 아래 5줄을 1줄로 save 할 수 있다. (적절한 메소드)
{Math.min(7 - max, 6), Math.min(7 - min, 6)};
반응형
반응형

어떤 삶을 살고 싶은가

오늘이 마지막 날이라면 실패한 일과 시도하지 않은 일 중 어느 걸 후회할 것인가

자기 합리화가 아닌 자기 객관화로  무엇에 익숙해져 있는지, 깨야하는지를 알아야 한다

새로운 길, 메뉴 등 사소한 것부터 도전하다 보면 큰 도전을 할 때도 잘할 수 있게 된다

노력해도 결과가 나오지 않거나. 지금이 만족스럽지 않다면 안전지대를 벗어나자

나를 움직이게 하는 장치 = 나에게 필요한 좋은 습관

습관의 시스템화 : 의지가 아닌 공부 스터디 식사처럼 이어지는 강제 기능

애쓰지 않는 습관 만들기.

스몰 빅 =이불 정리로 자신감 쌓기. 작은 성공경험

큰 실패는 작은 실패들을 이 쓰는데. 다시 작은 성공을 경험하자

결정을 못 하고 있다면. 목표가 없는 것

성과가 아닌 개인적인 발전의 관점에서 목표를 설정하자

인생은 선택의 연속. 나의 선택은 점이 되고 시간이 지나 점이 연결되면 내가 원하는 인생의 방향에 가까워진다

이직 준비 시 쉬운 문제를 풀고 스스로 칭찬하고 응원하는걸 동력 삼아 성공

무의식적으로 칭찬하다 보니 잘한다고 믿게 된다

습관화된 행동은 무의식 화가 되어 가 석화된다

결과(성적)가 아닌 과정(공부, 루틴)을 목표로 하자

큰 그림과 커리어 목표가 있으면 일희일비하지 않고. 더 넓은 시야와 필요한 곳에 선택과 집중 가능

공부는 새로운 삶을 위한 레버리지

공부가 습관이 될 때까지 환경을 만들기

흔들린다면 목표를 다시 잡자

슬럼프에서 빠져나오는 3가지 방법

남이 아닌 나에 집중. 일희일비 x. 예측 불가능한 상황에 심리적 대비

성적을 올린 5가지 방법

아침 15분 동안 하루를 준비. 공부는 20분씩 집중. 저녁 15분은 하루를 돌아보며 피드백. 작은 디테일은 과감히 포기(모르면 넘어가자). 나보다 잘하는 친구의 능력

공부하는 사람에게 필요한 사람: 멘토와 페이스메이커

듣는즉 시 나만의 언어로 바꾸어 기록하자

번아웃이 오면 나의 목표를 상ㄱ시키자

의지가 약할수록 스터디의 힘을 빌리자

단기적으론 비관론자. 장기적으론 긍정론자

시간을 버리는 사람 vs 버는 사람

하루 시간 관리법

오늘 해야 하는 가장 중요한 일 3가지만 정한다 (선저축 후소비처럼, 목적의식을 가짐)

이메일은 업무의 시작과 끝에 딱 2번만 확인

회의와 미팅은 하루에 몰아서 잡는다 (일하는 시간을 잡아서 업무 효율성을 높임)

스케줄에 없는 일은 절대로 하지 않는다 (내게 주어진 우선순위 일처리)

하루 30분은 무조건 운동

나는 완벽한 사람이 아닌다. 성과를 내는 사람이다

완성 후 공유가 아닌, 선공유/후 수정으로 빠른 피드백을 받자(빠른 반복, 빠른 실패)

린하게 일하자 :

Lean, 요즘 IT 스타트업은 빠르게 피드백으로 제품 개발 및 출시하고, 성과를 측정

끊음과 쉼이 중요하기 때문에, 70% 정도만 완성이 되면 공유 후 피드백 (20:80 법칙)

남에게 맡기자 : 직급이 올라갈수록, 능력이 있을수록 쉽지 않겠지만 남의 능력을 사용해야 효율적으로 일을 처리할 수 있고, 시간을 아낄 수 있다

일과 공부를 함께 하기 위한 타임 레버리지

콘텍스트 스위칭 : 여러 가지 일을 동시다발적으로 하기 → 정말 새로운 환경에 노출시키는 습관

블록 타임 : 시간을 벌자 → 개인 업무에 온전히 집중하는 완충 시간 확보 (목요일은 회의 없는 날)

더 많은 일하려는 욕심을 버리자 : 나의 목표만큼 끝냈다면, 타협하자 (일에는 끝이 없다)

나만의 시차 : 평소보다 1시간 일찍 일어나기

시간을 알차게 활용하는 시간 분배법

1주의 테마 정하기 : 이번 주 우선순위 = 테마 (프로젝트, 운동, 취미) ⇒ 무엇에 집중/우선순위

세부 카테고리 설정하기 : 구체적으로 적기

하일과 예상 소요시간 작성하기 : 각 요일별 할 일과 소요시간 정리 (최대 8시간/일)

오늘 거절하는 일이 내일 더 많은 시간을 만들어준다

: 내일 더 많은 시간을 만드는 일에 오늘 시간을 투자하는 자세를 가지면 시간을 크게 늘릴 수 있다

자신만의 기준이 있으면 시간을 낭비하지 않는다 : 시간을 잘못 쓰는 사람은 기준이 없는 사람

나보다 일 잘하는 사람의 시간을 훔쳐라

그들의 일처리 방법을 배우면, 비슷한 수준까지라도 갈 수 있다

나보다 잘하는 사람 : 서로 성장하며, 노하우를 얻을 수 있다

목표를 이루는데 도움이 되는 사람 : 조직 리더, 나의 목표, 커리어, 개인 비전까지 크고 작은 고민을 논의 (거시적 관점)

성공의 정의는 세상이 아닌, 스스로가 내리는 것

페이스북 합격

100%가 아닌 120%를 준비하라

트렌드 분석이 아닌 전반적인 깊이를 갖는 것이 좋다 (개인차 있음, 심리적 요인 등)

첨삭은 1명에게

사공이 많으면 산으로 간다 (업무 지시도 여럿에게 받으면 산으로 간다)

무조건 합격하는 면접비법

면접 장소에 일찍 도착 : 아이스 브레이킹 하면서 소개, 정보 들을 수 있다. 긍정적 이미지는 덤

리서치를 제대로 한다 : 대화를 하다 보면, 어느 정도로 준비했는지가 보인다

멍청한 질문은 하지 마라 : 단순 구글링으로도 나오는 질문 (회사의 최신 기사를 물어보자)

벼락치기는 없다 : 차라리 1,2일 전에는 운동&휴식으로 컨디션 조절이 중요

하버드와 스탠퍼드가 선택한 이유

스토리텔링 & 브랜딩 : 아이폰의 스펙 없이 발표한 스티브 잡스처럼, 어떤 스토리가 있는지

나만의 가치와 경험/해석이 필요 (연결해서 설명)

소비자 중심적 사고 : B2C에서도 필요한 사고방식

매력적인 자소서 쓰는 법

점들을 연결하라 : 인생의 점들을 하나로 연결하는 삶의 철학, 목표를 갖고, 방향을 재정비해보는 시간을 갖자

경쟁을 잘하는 사람이 아닌 대체 불가능한 사람이 되자

경쟁은 패배자들이나 하는 것

다른 경쟁자가 아닌 내가 뽑혀야 하는 이유를 만들자

남들에게 흔들리지 말고 중심을 잡자 : 친구 따라 하는 게 아닌, 자기중심이 있는 사람

내면의 목소리에 귀 기울이자 : 어떤 삶을 살고 싶은지, 본인에게 집중하는 시간

비슷한 목표를 가진 사람들과 네트워크를 형성하자

나와 비슷한 사람들이 모인 곳

주변 사람들이 곧 당신

반응형
반응형

상황

 월별로 데이터가 가장 많이 들어온 날짜를 구하는 쿼리가 필요

 

방법

Group by & order by & 서브쿼리를 활용
(key = group by 가장 상위의 데이터로 그룹핑 되므로, order by 사용하면 내가 원하는 데이터를 위로 올릴수있다)

 

아이디어

  • 그룹핑 (group by yyyymmdd) + 정렬(order by yyyymm), count(데이터수)
  • 서브쿼리2 : 위의 내용을  월별로 그룹핑

  • 그룹핑 (Group by yyyymm)
  • 그룹함수를 이용한 결과 출력

기존 쿼리

select
    max(bill_dt.readDt) readDt,
    max(bill_dt.oneMonthAgo) oneMonthAgo,
    max(bill_dt.twoMonthAgo) twoMonthAgo,
    max(bill_dt.threeMonthAgo) threeMonthAgo
from (
    select
        case
            when substring(READ_DT,1,6) = date_format(concat( ${read_dt},'01'), '%Y%m') then READ_DT
        end as 'readDt',
        case
            when substring(READ_DT,1,6) = date_format(date_add(concat(${read_dt},'01'),INTERVAL -1 Month), '%Y%m') then READ_DT
        end as 'oneMonthAgo',
        case
            when substring(READ_DT,1,6) = date_format(date_add(concat(${read_dt},'01'),INTERVAL -2 Month), '%Y%m') then READ_DT
        end as 'twoMonthAgo',
        case
            when substring(READ_DT,1,6) = date_format(date_add(concat(${read_dt},'01'),INTERVAL -3 Month), '%Y%m') then READ_DT
        end as 'threeMonthAgo'
    from gnd_meter_billing gmb
    where 조건 1
    and 기간 between 기간1 and 기간2
    group by substring(READ_DT,1,6), substring(READ_DT,7,2)
    order by cnt_readDt desc
    ) bill_dt

수정 쿼리

select
    max(bill_dt.readDt) readDt,
    max(bill_dt.oneMonthAgo) oneMonthAgo,
    max(bill_dt.twoMonthAgo) twoMonthAgo,
    max(bill_dt.threeMonthAgo) threeMonthAgo
from (
    select *
    from (
        select
            count(READ_DT) cnt_readDt,
            substring(READ_DT,1,6) yyyymm, 
            case
                when substring(READ_DT,1,6) = date_format(concat( ${read_dt},'01'), '%Y%m') then READ_DT
            end as 'readDt',
            case
                when substring(READ_DT,1,6) = date_format(date_add(concat(${read_dt},'01'),INTERVAL -1 Month), '%Y%m') then READ_DT
            end as 'oneMonthAgo',
            case
                when substring(READ_DT,1,6) = date_format(date_add(concat(${read_dt},'01'),INTERVAL -2 Month), '%Y%m') then READ_DT
            end as 'twoMonthAgo',
            case
                when substring(READ_DT,1,6) = date_format(date_add(concat(${read_dt},'01'),INTERVAL -3 Month), '%Y%m') then READ_DT
            end as 'threeMonthAgo'
        from gnd_meter_billing gmb
        where 조건 1
        and 기간 between 기간1 and 기간2
        group by substring(READ_DT,1,8)
        order by substring(READ_DT,1,6), cnt_readDt desc
        ) bill_dt_by_yyyymmdd
        group by bill_dt_by_yyyymmdd.yyyymm
    ) bill_dt
반응형
반응형

현상

ChargeUtil chargeUtil = new ChargeUtil();

이런식으로 chargeUtil 의 내부 메소드로 application.properties에 정의되어 있는 값을 @value 가져오는데

모든 값이 null 나오는 상황

 

원인

new 이용해 클래스를 인스턴스화 하면 스프링이 관여하지 않아 어노테이션(@value)이 무시

참고 : https://stackoverflow.com/questions/4130486/spring-value-annotation-always-evaluating-as-null

반응형

해결

new ChargeUtil() 를 제거하고, 스프링이 관여할 수 있도록 @Autowired를 쓰도록 코드 수정

  • ChargeUtil.java 를 bean으로 등록 (ex. @Component, @Service 등등)
  • @Autowired를 사용해 ChargeUtil를 사용하면, 스프링이 관여하기 때문에 정상적으로 값을 불러온다

 

반응형
반응형

Case문이란?

쿼리에서 If / Switch문의 역할

= 조건을 이용한 결과값 출력

 

사용 방법

  • CASE문은 조건을 통과 첫번째 조건이 충족되면 값을 반환
  • 조건이 true : 결과 반환,
    조건이 false : else 값을 반환
  • Else문이 없으면 null 반환
  • When - then 항상 같이 사용하며, 여러 set 사용가능

 

예제

특정 기간 동안의 원하는 날짜를 가져오는 쿼리

= 검색 기준으로부터 해당월, 1달전, 2달전, 3달전, 4달전, 12달전, 13달전의 결제일(=해당월의 가장큰 read_dt) 검색

= case when read_dt 202203이면 read_dt 출력하되, 'read_dt'라는 이름으로 출력
 case when read_dt 202202이면 read_dt 출력하되, 'oneMonthAgo'라는 이름으로 출력

= 하나의 컬럼을 여러 개의 컬럼(=하나의 로우)으로 출력 가능

 

 

    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
   31
   32
   33
   34
   35
   36
   37
   38


select
        max(bill_dt.readDt) readDt,
        max(bill_dt.oneMonthAgo) oneMonthAgo,
        max(bill_dt.twoMonthAgo) twoMonthAgo,
        max(bill_dt.threeMonthAgo) threeMonthAgo,
        max(bill_dt.fourMonthAgo) fourMonthAgo,
        max(bill_dt.twelveMonthAgo) twelveMonthAgo,
        max(bill_dt.thirteenMonthAgo) thirteenMonthAgo
from (
        select
                case
                        when substring(READ_DT,1,6) = '202203' then READ_DT
                end as 'readDt',
                case
                        when substring(READ_DT,1,6) = '202202' then READ_DT
                end as 'oneMonthAgo',
                case
                        when substring(READ_DT,1,6) = '202201' then READ_DT
                end as 'twoMonthAgo',
                case
                        when substring(READ_DT,1,6) = '202112' then READ_DT
                end as 'threeMonthAgo',
                case
                        when substring(READ_DT,1,6) = '202111' then READ_DT
                end as 'fourMonthAgo',
                case
                        when substring(READ_DT,1,6) = '202103' then READ_DT
                end as 'twelveMonthAgo',
                case
                        when substring(READ_DT,1,6) = '202102' then READ_DT
                end as 'thirteenMonthAgo'
        from gnd_meter_billing gmb
        where READ_DT between 20210301000000 and 20220322000000
group by substring(READ_DT,1,6), substring(READ_DT,7,2)
) bill_dt
;
반응형
반응형

최고의 투자자 워렌버핏이 배당금으로 2년마다 원금 회수하는 주식 = 코카콜라

위의 내용을 요약하면, 지금으로부터 30년전에 투자를 했다고 하고, 현재 기준으로 배당률이 50%가 넘는다고 합니다 ㅎㄷㄷ

 

우리나라에도 코카콜라 못지 않게 꾸준히 우성장하면서, 한국 기업치고 배당금을 잘 주는 기업이 있죠! 외쳐 삼성전자

한국에서는 대부분 연배당이지만, 삼전은 분기배당으로 주고 있고, 배당금액도 올라가고 있고, 무엇보다 주가도 잘 오르기 때문에, 장기적으로 보면 괜찮은 접근이라고 생각이 됩니다

 

특히나, 삼전은 최근에 계속 조정을 받고 있어서 7만전자의 선이 깨지고 6만원대 후반까지 떨어져있어서 매력적인 구간이라고 보여집니다.

 

 

일단 오늘의 주제인 배당률에 대해 비교해보겠습니다.

같은 조건에서 2개 기업의 배당률과 수익률을 계산했습니다

(1월 시가 기준, 현재가는 22년 4월 5일 기준)


코카콜라

91년01월 가격 : 4.87달러

11년01월 가격 : 32.94달러

현재가격 : 62.88달러

연배당금 : 1.68달러

현재 배당률 : 2.6% (= 1.68 / 62.88 * 100)

30년전에 샀을때 배당률 : 34% (= 1.68 / 4.87 * 100)

10년전에 샀을때 배당률 : 5.1% (= 1.68 / 32.94 * 100)


삼성전자

91년01월 가격 : 312원

11년01월 가격 : 19100원

현재가격 : 69200원

연 배당금 : 1444원

현재 배당률 : 2.08% (= 1444 / 69200 * 100)

30년전에 샀을때 배당률 : 462% (= 1444 / 312 * 100)

10년전에 샀을때 배당률 : 7.5% (= 1444 / 19100 * 100)


 

허허...

30년전에 코카콜라 주식을 산 워렌 버핏은 매년 34%의 이자를 받습니다

(버핏 할아버지는 88년도부터 샀기 때문에 더 싸고, 배당률이 높아서 52%정도 된다하네요)

30년전에 삼성전자 주식을 산 누군가는 매년 원금의 4배이상을 받고 있네요//

 

결론

다시 보자 삼성전자!

  • 계속해서 오르는 주가(성장성)
  • 점점 높아지는 배당금(+앞으로는 좀 더 주주 친화적이게 변신하지 않을까..)

하지만, 여기서 조심해야 할 포인트가 2가지 있는데요!

1. 배당

  • 꾸준히 우성장하면서, 배당을 수십년간 끊기지 않고 늘려온 코카콜라와 달리,
    삼성전자는 배당금을 언제부터 줬는지 확인하지 못했지만, 코카콜라보다는 배당 역사가 많이 짧을겁니다.

2. 성장성

  • 사실 삼전의 이자율이 저렇게 사기급으로 나온 이유는 반도체, 휴대전화 사업을 성공적으로 이끌면서 엄청난 성장을 했기 때문에, 주가가 코카콜라에 비해 급격하게 많이 올라서, 더 많이 주는것처럼 보여집니다.

 

진짜 결론!!

앞으로도 삼전이 세계 탑티어의 반도체, 전자제품, 휴대폰 시장을 장악해서 살아남는다면, 엄청난 성장주이면서 동시에 엄청난 배당주가 될 수 있어 보입니다.

 

하지만! 배당주더디더라도 꾸준히 배당률을 올려가면서, 끊기지 않고 돌려줘야 한다고 생각합니다. 

코카콜라가 소비재로써 그래서 더 적합한 주식이라 생각되긴 하네요.

하지만 저는 코카콜라보단 삼전에 투자하겠...

반응형
반응형


삼슬라에 대해 궁금하신 분은 전에 작성한 아래 글에서 확인!

 

삼슬라 : 테슬라 3배 레버리지 (TSL3)

엊그제가 천이백슬라고 어제가 천슬라같은데 팔백슬라라니... 머스크 형이 세금 낸다고 테슬라 팔고(최대 주주 리스크), 테이퍼링+금리 때문에 조정 받는 장이라고는 하지만! 포트폴리오의 가장

fire-programmer.tistory.com


투자 정보

매도 종목 : TSL3
매도 가격 : \7001 (매수가:\5167, 수량:2771개)

총 투자금 : 1430만원

수익률 : 35.36% (수익:약 500만 원)
매도 이유 :

  • 메인 계좌에 테슬라를 이미 400 후반대에 들고 있는 대투자자로서, 테슬라에 대한 확신이 있었음
  • 과도한 폭락 시마다 계속해서 추매함 (테슬라 $900에서 사고 800 아래로 떨어질 때마다 계속 줍줍)
  • 테슬라의 가격이 목표가인 $1000이 장 중에 도달 하자마 수익 실현


투자 후기

  1. 리스크가 "진짜" 높다
  2. 수수료도 "진짜" 높다
  3. 낮은 거래량
  4. 영국에 상장
  5. 기타 제약 사항

설명

  1. 리스크가 "진짜" 높다 (장점 + 단점)
    -> 투자하고 있을 때 하나의 종목을 3배로 추종하다 보니 오르락/내리락이 더 다이나믹..
  2. 수수료도 "진짜" 높다 (단점)
    -> 0.0163%/1일 (5.94%/1년) 이보다 높은 수수료는 본 적이 없음
    -> 가만히 있어도 투자금이 매일 0.0163%씩 녹는 경험
  3. 낮은 거래량 (단점)
    -> 평균 거래량 40000건이 안 되는 지극히 적은 거래량
    -> 내가 팔고 싶어도, 팔리지 않을 수 있는 리스크 존재
    -> 오죽하면 매도 할 때 1500만 원어치를 한 번에 걸었더니, 나 혼자서  당일 최고 막대기 세움 (아래 스샷)
  4. 영국에 상장 (단점)
    -> 우리나라에서는 삼성증권 말고, 다른 증권사는 매매 자체가 불가능 (영국 시장)
  5. 제약사항 (단점)
    -> 당일 매수 후 5일 이후 매도 가능 (3~5일 정도인 듯)
    -> 최소 매도 물량 있음 (최소 10개 이상 있어야 매도 가능)

결론

엄청난 단점이 무려 4개나 있지만!! (높은 수수료, 낮은 거래량, 영국 시장의 불편한 접근성, 기타 많은 제약 사항)

그걸 커버할 만큼의 수익률이기 때문에 투자했지만! 장이 좋지 않으면 진짜 위험할 듯

이미, 테슬라 주주로써 확실한 믿음이 있기 때문에 평단가를 높이지 않고도 더 많은 수익 창출 가능!!

앞으로도 테슬라 800선이 위태하면, 투자를 고려할 마음이 있다!

FNGU, BULZ에 투자해서 손절하고 여기에 물 타서 투자한 게 신의 한 수였다! 
-700중에 500을 해결해주신 귀인.. 오늘도 테멘

 

반응형
반응형

망했을때 어떻게 할것인가를 고민하는것이 중요한 이유(정리)

  • 현실에서 망했을때의 예
    = LOL
    실버에서 플레까지 방법 : 망했을때 어떻게 1인분을 할것인가... 고민해보았다
  • 망한 판을 어떻게 복구할것인가?
    = 5
    질것을 3번지면서 승률이 높아짐
  • 개발자로써 망한판
    =
    개발환경/경험 낙후, 테스트코드/코드리뷰등 개발 문화 전무,  레거시 높은 프로젝트, 팀동료의 실력
  • 엉망인 환경을 피할 확률을 높일 수는 있지만, 100% 없다
  • 엉망인 판을 만났을때
    =>
    해먹겠다 vs 그럼에도 불구하고 해야겠다 (후자가 회사가 기대하는 시니어)
  • 풀리는 판에서는 본인의 기량을 확인하기 어렵다
  • 시니어 개발자의 역할
    = 망한 판을 어떻게 정상화 시키냐 (스타트업은 99%확률로 레거시 해결해야 )
  • 이럴때 너무 절망하지 말고,
    드디어 역량을 뽐낼 기회가 왔다! 생각하면 본격적으로 성장할 있는 기회 된다!
  • 잘되는 판은 잘해도 본전
    망한 판은 못해도 본전
    망한 판을 잘하면 영웅
  • 하지만 무엇이 문제인지를 모르는건 가장 이다
  • 무엇이 문제인지를 알기 위해선, 한 번 쯤 좋은 개발환경, 개발문화, 좋은동료를 경험해봐야 한다

오늘도 띵언을 남겨주셔서 감사합니다

출처 : https://jojoldu.tistory.com/599

반응형
반응형

Where 1=1 처럼 동적으로 set 컬럼을 바꾸고 싶을때

 

방법1. Mybatis 해결 : <set> 사용 (추천)

        <set>

            <if test="meterChangeUsage != null and meterChangeUsage !=''">

                gmp.METER_CHANGE_USAGE = #{meterChangeUsage} ,

            </if>

            <if test="meterChangeDt != null and meterChangeDt !=''">

                gmp.METER_CHANGE_DT = #{meterChangeDt} ,

            </if>

            <if test="contractMethod != null and contractMethod !=''">

                gai.CONTRACT_METHOD = #{contractMethod} ,

            </if>

            <if test="contractCapacity != null and contractCapacity !=''">

                gai.CONTRACT_CAPACITY = #{contractCapacity} ,

            </if>

        </set>

 

방법2. 쿼리로 해결 : 바꾸려는 컬럼을 기존 값으로  번더 사용     (비추) 

            set gmp.METER_CHANGE_USAGE =  gmp.METER_CHANGE_USAGE

            <if test="meterChangeUsage != null and meterChangeUsage !=''">

                gmp.METER_CHANGE_USAGE = #{meterChangeUsage} ,

            </if>

            <if test="meterChangeDt != null and meterChangeDt !=''">

                gmp.METER_CHANGE_DT = #{meterChangeDt} ,

            </if>

            <if test="contractMethod != null and contractMethod !=''">

                gai.CONTRACT_METHOD = #{contractMethod} ,

            </if>

            <if test="contractCapacity != null and contractCapacity !=''">

                gai.CONTRACT_CAPACITY = #{contractCapacity} ,

            </if>

 

<set> 사용시 마지막 ,(콤마) 자동적으로 제거

 

반응형

+ Recent posts