728x90
728x90

Python Selenium


from selenium import webdriver
from webdriver_manager.chrome import ChromeDriverManager

driver = webdriver.Chrome(ChromeDriverManager().install())
os.makedirs(path, exist_ok=True)

이미지 저장

urlretrieve

JPA


  1. 연관관계가 있는 데이터 변경시에는 기존에 데이터가 있는지 확인하자
  2. @MappedSuperClass abstract
  3. @AttributeOverride,@AttributeOverrides
  4. @AssociationOverride,@AssociationOverrides
  5. 식별자, 비식별자
  6. @IdClass
  7. @EmbeddedId / implements Serializable / method equals / method hasCode Override / Noargs Constructor / public
  8. @JoinColumns / referenceedColumnName
  9. 조인 컬럼 / 조인 테이블
  10. 즉시 로딩 fetch = FetchType.EAGER / 지연 로딩 fetch = FetchType.LAZY
  11. inner join : nullable =false or ManyToOne Option = false <=> outer join : nullable = true
  12. 영속성 전이 : CASCADE
  13. CASCADE TYPE : ALL,PERSIST,MERGE,REMOVE,DETACH,REFRESH
  14. 고아객체 : ORPHAN : orphanRemoval = true
  15. Embedded Type => @Embeddable
  16. 값 타입 불변과 객체
  17. Embedded 값 타입 복사
  18. 값 타입 컬렉션 : @ElementCollection
  19. JPQL
  20. fetch 조인 : join fetch
  21. queryDSL
  22. 벌크연산
728x90

'개발일기' 카테고리의 다른 글

[TIL#11]  (0) 2023.06.13
[TIL#10]  (0) 2023.06.12
[TIL#9]  (2) 2023.06.09
[TIL#7]  (0) 2023.06.02
[TIL #4]  (0) 2023.05.03
728x90

Docker


Install - Unbuntu

# Docker
sudo apt-get update
sudo apt-get install ca-certificates curl gnupg

sudo install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
sudo chmod a+r /etc/apt/keyrings/docker.gpg

echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
sudo usermod -aG docker ${USER}

Linux Ubuntu


  1. 그냥 내가 사용자 추가 할때 쓰는 코드
  2. useradd -m user passwd user echo "user ALL=(ALL) NOPASSWD:ALL">>/etc/sudoers

## mariadb conf
[client]  
port = 3306  
default-character-set=utf8

[mysqld]  
#bind-address = 127.0.0.1  
bind-address = 0.0.0.0

key_buffer_size = 512M  
innodb_buffer_pool_size = 512M

init_connect="SET collation_connection=utf8_general_ci"  
character-set-server = utf8  
collation-server = utf8_unicode_ci

[mysql]  
default-character-set=utf8

Spring boot


  1. gradle dependency 추가 : implementation 'org.bgee.log4jdbc-log4j2:log4jdbc-log4j2-jdbc4.1:1.16'
  2. log : log4jdbc.log4j2.properties 추가
log4jdbc.spylogdelegator.name=net.sf.log4jdbc.log.slf4j.Slf4jSpyLogDelegator  
log4jdbc.dump.sql.maxlinelength=0
  1. application.yml 수정
spring.datasource.driverClassName=net.sf.log4jdbc.sql.jdbcapi.DriverSpy  
jdbc:log4jdbc:mariadb://

~~~
  1. logging
  2. logging: level: root: INFO org: hibernate: type: TRACE SQL: INFO jdbc: audit: OFF resultset: OFF resultsettable: INFO sqlonly: OFF sqltiming: INFO connection: OFF
  3. @EntityListeners(AuditingEntityListener.class)
  4. @EnableJpaAuditing

VScode


  1. spring boot args
  • launch.json
"args": "--spring.profiles.active=local"  
728x90

'개발일기' 카테고리의 다른 글

[TIL#10]  (0) 2023.06.12
[TIL #8]  (0) 2023.06.09
[TIL#7]  (0) 2023.06.02
[TIL #4]  (0) 2023.05.03
[TIL #3]  (0) 2023.05.02
728x90

Git


  1. git branch
  2. git add *
  3. git commit -m "메세지"
  4. git push origin 브랜치

Spring Boot


  1. 정적 파일 Resource 경로 설정 -> addResourceHandlers
  2. AOP

JPA


  1. 컬럼이 많을 때는 DynamicUpdate 어노테이션을 사용해 보자
  2. 영속성
  3. 1차 캐싱
  4. 삭제는 remove()
  5. persist()
  6. JPQL 실행시 flush 자동 호출
  7. flush 모드 설정 : FlushModeType.AUTO / FlushModeType.COMMIT - EntityManager setFlushMode() 사용
  8. 준영속성 : 영속성 -> 준영속성 : detach(Entity) 특정엔티티만, close() 종료, clear() 초기화
  9. 병합 : merge() 준영속성 -> 영속성
  10. @Entity : name을 설정하지 않으면 그대로 사용 / 기본 생성자는 필수 / final,enum,interface,inner 에는 사용할 수 없다. 저장할 필드에 final을 사용하면 안된다.
  11. @Table: name 생랴기 Entity 이름 사용 /
  12. @Enumerated : Java enum 매핑 / EnumType.String
  13. @Temporal : 날짜 타입 매핑
  14. @Lob: CLOB, BLOB 을 매핑
  15. 스키마 자동 생성 : 기존 테이블 지우고 다시 생성 / 개발에서만 사용하자
    # application.properties
    spring.jpa.hibernate.ddl-auto=update
    

XML

hibernate.hdm2ddl.auto value="create"

16. sql_show

#application.properties
spring.jpa.hibernate.sql_show=true

XML

hibernate.sql_how value="true"

17. 매핑 전략 변경
- hibernate.ejb.naming_strategy

18. nullable = false : not null 추가
19. length = 10 : 길이 추가
20. 유니크 제약 조건 : @table(name="..", uniqueConstraints={@UniqueConstraint(name="...",columnNames={"...","..."})})
21. @GeneratedValue : 기본 키 생성 전략
22. @Id 매핑 가능한 타입 : 기본 , Wrapper, String, Date, BigDemical, BigInteger
23. IDENTITY 전략 : MySql , postgresql, SQL Server : AUTO_INCREMENT 가 있는 밴더 : @GeneratedValue(strategy=GenerationType.IDENTITY)
24. SEQUENCE 전략: 오라클, postgresql : @SequenceGenerator(name="...",sequenceName="...",initialValue=1,allocationSize=1) +  @GeneratedValue(strategy=GenerationType.SEQUENCE,generator="...")
25. Table 전략 : 키생성 전용 테이블을 만들어 사용 : @TableGenerator(name="...",table="...",pkColumnValue="...",allocationSize=1) +@GeneratedValue(strategy=GenerationType.TALBE,generator="...")
26. Auto 전략 : 자동 : @GeneratedValue(strategy=GenerationType.AUTO)
27. Transient: DB 매핑x
28. Access : JPA 접근 방식 지정
29. @Column : name, nullable , length ,(BigDemical,BigInteger) percision, scale
30. @Colomn 생략지 자바 타입이 기본 타입일 경우를 주의하자
31. @Enumerated : EnumType.ORDINAL enum에 정의된 순서, EnumType.String enum정의된 이름 그대로, 
32. @Temporal: Date,Calendar 등 날짜타입 TemporalType.DATE , TemporalType.TIME, TemporalType.TIMESTAMP, 생략시 Timestamp
33. @Access : 엔티티 접근방식 : AccessType.FIELD 필드 직접 접근, AccessType.PROPERTY 접근자 : 사용 생략시 @Id 위치에 따라 접근
34. 연관 관계
35. 방향 : 단방향, 양방향
36. 다중성: N:1, 1:N, 1:1, N:M
37. OWNER : 양방향으로 만들면 OWNER 를 정해야한다.
38. N:1 단방향 연관관계 : x는 하나의 y , y에는 여러 x, 게시물은 1명의 유저, 유저는 여러개의 게시물
39. x에는 y로 접근하는 필드 존재 , x에서는 y로 접근가능 , y에서는 x로 접근 불가
40. @ManuToOne : optional, fetch, cascade, targetEntity: 연관관계 엔티티 타입
41. @JoinColumn(name="연관관계 테이블 컬럼")
728x90

'개발일기' 카테고리의 다른 글

[TIL #8]  (0) 2023.06.09
[TIL#9]  (2) 2023.06.09
[TIL #4]  (0) 2023.05.03
[TIL #3]  (0) 2023.05.02
[TIL#2]  (0) 2023.04.27
728x90

Web Analytics GA4(Google Analytics)


  1. 링크 : https://support.google.com/analytics/answer/9143382?sjid=1232095385863967603-AP#link&zippy=%2C%EB%A7%81%ED%81%AC
  2. outbound : 외부 링크 연결 추적 (Boolean) 링크가 속성 도메인의 일부가 아닌 웹사이트로 연결되는 경우 텍스트는 'true'입니다.
  3. 자동 수집 이벤트

영어 단어


  1. asterisk = *

Deep learning - pytorch


  1. Loss Function -> smooth_l1_loss
  2. Optimizer -> torch.optim.LBFGS -> closure 함수를 매개변수로 넣어줘야함
  3. torch.nn.lstm -> outputs , hidden return

JAVA - Spring


  1. tomcat timeout 45s-> timeouts 시간 늘리기

python - cv2


  1. numpy -> cv2.imshow("title",np.array)
  2. cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
728x90

'개발일기' 카테고리의 다른 글

[TIL#9]  (2) 2023.06.09
[TIL#7]  (0) 2023.06.02
[TIL #3]  (0) 2023.05.02
[TIL#2]  (0) 2023.04.27
[TIL #1]  (0) 2023.04.25
728x90

라즈베리파이


  1. 구입처 기록
    https://www.devicemart.co.kr/goods/view?no=12553062
    https://www.eleparts.co.kr/promotion/cate_event?event_seq=1622

Dart


  1. json데이터 사용시 dart:convert 이용
  2. jsonDecode 를 사용해 json 문자열을 decode 한다.
  3. var 타입 또는 Map<String,dynamic>으로 받는다.
  4. 배열형태로된 문자열의 경우에는List 로 받아 준다.
  5. stream 사용법 추가 공부를 해보자 async* yield
  6. stream then 사용 : first,laset,isEmpty,length
  7. random 함수는 dart:math에 있음
  8. hash 류는 dart:collection

JAVA - Spring


  1. Poi Excel cell값을 가져올때 type을 잘 보고 가져오자.

Flutter


  1. 초기 생성시 lib > main.dart 파일
  2. lib 폴더에만 집중하자.
  3. root 디렉토리 > pubspec.yaml 파일 flutter에서 쓰이는 패키지,이미지,폰트등
  4. dart 파일 첫 줄 import 문 > java 와 비슷
  5. import "package:flutter/material.dart"
728x90

'개발일기' 카테고리의 다른 글

[TIL#7]  (0) 2023.06.02
[TIL #4]  (0) 2023.05.03
[TIL#2]  (0) 2023.04.27
[TIL #1]  (0) 2023.04.25
[개발일기] #4 - 네이밍에 관한 생각_ 2021.04.03  (0) 2021.04.03
728x90
728x90

+ Recent posts