반응형

ORA-12899: "SYSTEM"."POKEMON_MSTR"."DETAIL" 열에 대한 값이 너무 큼(실제: 136, 최대값: 128)

 

ALTER TABLE POKEMON_MSTR MODIFY(DETAIL varchar2(200));

내가 입력할 값보다 더 큰 크기로 값을 수정해주면 해결할 수 있다.

반응형
반응형

오라클 데이터 베이스 공부를 하기위해 임의의 데이터 테이블을 생성하고 해당 테이블에 데이터를 넣어보고 있다.

 

테이블 칼럼은 pno(number), pname(varchar), categorize(varchar)로 생성하였으며

INSERT INTO POKEMON_MSTR
VALUES(0001,'이상해씨','씨앗포켓몬');

다음과 같이 INSERT문을 통해 데이터를 입력할 수 있다.

 

하지만 내가 원하는건 한번에 데이터를 넣는 것...

INSERT INTO POKEMON_MSTR
VALUES(0004,'파이리','도롱뇽포켓몬'),
	(0005,'리자드','화염포켓몬'),
	(0006,'리자몽','화염포켓몬');
SQL 오류: ORA-00933: SQL 명령어가 올바르게 종료되지 않았습니다
00933. 00000 -  "SQL command not properly ended"

단순히 VALUES를 반복해서 작성하는 것으로는 sql문이 종료되지 않았다는 오류만 뱉어낼 뿐이다

 

INSERT ALL
    INTO POKEMON_MSTR
    VALUES (4, '파이리', '도롱뇽포켓몬')
    INTO POKEMON_MSTR
    VALUES (5, '리자드', '화염포켓몬')
    INTO POKEMON_MSTR
    VALUES (6, '리자몽', '화염포켓몬')
SELECT *
FROM DUAL;

 

다음과 같이 INSERT ALL을 써서 데이터를 넣어주면 데이터를 성공적으로 넣을 수 있다.

서브쿼리를 필요로 하기 때문에 SELECT * FROM DUAL;을 작성해준다.

 

∩  ∩

ฅ(=ˇωˇ=)ฅ

반응형
반응형

Window > Preferences > General > Editors > Text Editors > Colors and Font. 클릭 후 edit

Window > Preference  > General > Appearance > Colors and Fonts > Basic 스크롤 후  Text Font > edit

 

추천 폰트

 

네이버 D2 코딩

https://github.com/naver/d2codingfont

 

GitHub - naver/d2codingfont: D2 Coding 글꼴

D2 Coding 글꼴. Contribute to naver/d2codingfont development by creating an account on GitHub.

github.com

한글, 숫자, 영어의 유사 기호간의 변별력을 높여 디자인한 폰트 한글을 지원하는것이 가장 큰 장점

 

Consolas

윈도우에 기본으로 설치되어 있음

한글을 지원하지 않지만 기호간 변별력이 높고 개발에 적합한 폰트 기본적으로 많이 쓰이는 폰트라고 한다

 

 

반응형
반응형

클래스 안에는 두 개 또는 그 이상의 메서드를 사용할 수 있다.

 

main 메소드가 아닌 다른 메서드는 자동로 실행되지 않아서 main 메소드에서 호출해야만 실행된다.

 

메서드 호출

public class Example01 {

	public static void main(String[] args) {
		System.out.println("첫번째 메소드");
	}
	
	static void second(String text) {
		System.out.println("두번째 메소드");
	}

}
첫번째 메소드

위의 코드 실행결과는

"첫번째 메소드"

로 main 메서드의 print문만 실행되는데 second 메서드를 실행시키기 위해서는 main메서드에서 호출을 해줘야한다.

public class Example01 {

	public static void main(String[] args) {
		System.out.println("첫번째 메소드");
		
		second("두번째 메서드")
	}
	
	static void second(String text) {
		System.out.println(text);
	}

}
첫번째 메소드
두번째 메서드

 

메서드 호출문 작성

메서드 이름(파리미터1, 파라미터2, 파라미터3 ...)

파라미터는 없을 수도 있고, 1개 혹은 여러개 있을 수 있다

 

return 값을 받는 메서드 호출문

public class Example01 {

	public static void main(String[] args) {
		int result; // 변수 선언
		
		result = add(3,4);
		System.out.println(result);
	}
	
	static int add(int a, int b) {
		int sum = a + b;
		
		return sum;
	}
}

main 메서드에서 3과 4라는 파라미터를 add로 넘기면 add 메서드에서는 파라미터 값을 계산하고 호출한 곳으로 리턴 값을 넘겨준다.

뿐만 아니라 메서드의 실행을 종료하고 메서드를 호출한 곳으로 돌아가는 일도 한다.

 

메서드의 리턴 값을 계산하고 돌아감 메서드를 종료하고 호출 한 곳으로 돌아가기만 함
return sum;
return a + b;
return ;
  void 키워드가 붙은 메서드에서만 사용가능

 

반응형

'study > JAVA' 카테고리의 다른 글

[JAVA] 타입 변환  (0) 2023.02.27
[JAVA] 변수 타입과 값 할당  (2) 2023.02.26
[JAVA] 키워드와 식별자  (0) 2023.02.26
반응형

오렌지 > Tool > Orange Options > Common > Enviroment > Client > NLS_LANG 에 수기로

AMERICAN_AMERICA.KO16KSC5601

를 입력해준 후 오렌지를 재실행한다.

반응형
반응형

자동 타입 변환

자동 타입 변환은 값의 허용 범위가 작은 타입이 허용 범위가 큰 타입으로 정장될 때 발생

큰 허용 범위 타입 = 작은 허용 범위 타입

 

허용범위 크기순 정렬

byte < short < int < long < float < double
	public static void main(String[] args) {
		byte byteval = 2;
		int intval = byteval;
		
		System.out.println(intval);
	}

위의 코드의 경우 정상적으로 2가 출력되지만, 아래의 경우

	public static void main(String[] args) {
		int intval = 2;
		byte byteval = intval;
		
		System.out.println(byteval);
	}

Type mismatch: cannot convert from int to byte

다음과 같은 type mismatch 오류가 발생한다. 강제 타입 변환을 통해 해당 오류를 해결할 수 있다.

 

* char 타입보다 byte 타입의 허용범위가 작지만, char 타입은 허용범위 중 음수를 포함하지 않기 때문에 변환이 되지 않는다.

 

강제 타입 변환

캐스팅 연산자를 사용해서 타입을 강제 변환할 수 있다.

작은 허용 범위 타입 = (작은 허용 범위 타입)큰 허용 범위 타입

	public static void main(String[] args) {
		int intval = 2;
		byte byteval = (byte)intval;
		
		System.out.println(byteval);
	}

다음과 같이

byte = byteval = (byte)intval;

를 입력하면 강제로 타입을 변환할 수 있다

 

연산에서의 자동 타입 변환

정수 타입 변수가 산술 연산식에서 피연산자로 사용되면 int 타입보다 작은 byte, short 타입의 변수는 int 타입으로 자동 타입 변환된다.

	public static void main(String[] args) {
		byte val1 = 1;
		byte val2 = 2;
		
		byte var3 = val1 + val2; //오류 : Type mismatch: cannot convert from int to byte
        int var3 = val1 + val2 ; 
		
		System.out.println(var3);
	}

오류 : Type mismatch: cannot convert from int to byte

오류가 발생하므로 계산된 값은 int 변수에 저장해야한다.

 

피연산자 중 허용 범위가 더 큰 피연산자로 계산되므로 피연산자 중 long, double  이 있을경우 연산 결과는 범위가 큰 연산자로 저장되어야한다.

 

+ 연산자에서의 문자열 자동 타입 변환

+ 연산자는 둘 다 숫자면 덧셈연산, 하나라도 문자열이면 결합연산을 수행한다.

 

문자열을 기본 타입으로 강제 타입 변환

메소드를 이용해 강제 형 변환한다

String -> byte Byte.parseByte(str)
String -> short Short.parseShort(str)
String -> int Integer.parseInt(str)
String -> long Long.parseLong(str)
String -> float Float.parseFloat(str)
String -> double Double.parseDouble(str)
String -> boolean Boolean.parseBoolean(str)
반응형

'study > JAVA' 카테고리의 다른 글

[JAVA] 메서드 호출  (0) 2023.03.01
[JAVA] 변수 타입과 값 할당  (2) 2023.02.26
[JAVA] 키워드와 식별자  (0) 2023.02.26
반응형

변수

데이터를 저장하기 위해 프로그램에 의해 이름을 할당받은 메모리 공간

 

변수 선언

 

기본 형식

타입 식별자; 타입 식별자 = 초기값;

로컬 변수는 사용하기 전에 반드시 선언해야한다.

 

타입

 

변수의 타입 - 기본 타입

  • 정수 타입 : byte, char, short, int, long
  • 실수 타입 : float, double
  • 논리 타입 : boolean

정수리터럴 : 소스 코드에서 프로글래머에 의해 직접 입력된 값

2진수 : 0b or 0B로 시작, 0과 1로 구성

8진수 : 0으로 시작, 0~7로 구성

10진수 : 소수점이 없는 0~9로 구성

16진수 : 0x or 0X로 시작, 0~9 숫자와 a,b,c,d ,e,f 로 구성

 

	public static void main(String[] args) {
		int var1 = 0111;
		int var2 = 111;
		
		System.out.println(var1);
		System.out.println(var2);
	}
73
111

8진수의 경우엔 0111을 출력하는게 아닐까 생각했지만 0으로 시작된다면 8진수로 인식하고 73으로 10진수 변환되어 출력되었다.

 

실수리터럴

소스 코드에서 소수점이 있는 숫자 리터럴은 10진수 실수로 인식

알파벳 e, E 가 포함되어 있는 숫자 리터럴은 지수와 가수로 표현된 소수점이 있는 10진수 실수로 인식

	public static void main(String[] args) {
		double var1 = 10e2;
		
		System.out.println(var1);
	}
1000.0

 

 

*char 타입은 문자리터럴 이라고 하며 유니코드로 변환되어 자징되어서 정수 타입에 넣었습니다...

	public static void main(String[] args) {
		char var1 = "A";
		System.out.println(var1);
	}

오류: Type mismatch: cannot convert from String to char

 

자바에서 ""로 감싼 문자는 문자열로 char 타입이 아닌 String 타입으로 변수를 저장한다. 

char 타입에 ""로 감싼 문자열을 입력하면  type mismatch 에러가 발생한다.

 

식별자

자바 식별자 명명 규칙

  • 하나 이상의 글자로 이루어져야 한다
  • 첫 번째 글자는 문자이거나 $, _ 여야 한다
  • 두 번째 이후의 글자는 숫자, 문자, $, _dudi gksek
  • $, _ 이외의 특수 문자는 사용할 수 없다
  • 길이의 제한은 없다
  • 키워드는 식별자로 사용할 수 없다
  • 상수 값을 표현하는 단어는 식별자로 사용할 수 없다

값 저장

변수에 값을 저장할 때는 대입연산자 = 를 사용

오른쪽 값을 왼쪽에 저장한다는 의미

값을 저장하는 것을 변수 초기화라고 하며, 이 때 사용된 값을 초기값이라고 한다

	public static void main(String[] args) {
		int var1;
		
		System.out.println(var1 + 10);
	}

오류 :Unresolved compilation problem:The local variable "변수명" may not have been initialized

변수의 초기값을 할당하지 않고 사용하면 다음과 같은 오류가 발생한다.

해결방법 : 변수 초기화를 해준다

 

값을 바꿀 수 없는 변수

변수 앞에 final 키워드를 사용하면 해당 변수에 딱 한번만 값을 대입할 수 있다.

	public static void main(String[] args) {
		final double pi = 3.14;
		pi = 3-141592;
		
		System.out.println(pi);
	}

오류 : The final local variable "변수명" cannot be assigned. It must be blank and not using a compound assignment

final로 이미 한번 초기화 된 변수를 변경하려고 하니 다음과 같은 오류가 발생한다.

반응형

'study > JAVA' 카테고리의 다른 글

[JAVA] 메서드 호출  (0) 2023.03.01
[JAVA] 타입 변환  (0) 2023.02.27
[JAVA] 키워드와 식별자  (0) 2023.02.26
반응형

자바 프로그램의 구성요소

 

키워드

  • 자바에서의 예약어로 자바에서 키워드를 만들 때 정한 사용 목적 이외의 용도로를 쓸 수 없다.
  • 소문자로 되어있다

 

식별자

  • 클래스, 인터페이스, 변수, 메소드, 배열, 문자열을 구분할 수 있는 이름
  • 대소문자를 구분하여 사용

 

public class Hello {

	public static void main(String[] args) {
		System.out.println("Hello, Java");
	}

}

public class Hello {

public static void main(String[] args) {

System.out.println("Hello, Java");

}

}

키워드 : 메소드 앞에 반드시 써주어야 하는 것

식별자 : 키워드와 달리 클래스, 메소드, 변수에 붙이는 이름은 프로그래머가 정할 수 있음

 

키워드 종류

자바의 키워드

abstrack continue for new switch
assert default if package synchronized
boolean do goto private this
break double implements protected throw
byte else import public throws
case enum instanceof return transient
catch extends int short try
char final interface static void
class finally long strictfp volatile
const float native super while

상수 값을 표현하는 단어

true false null

(지금 외울 필요 x)

 

 식별자 명명 규칙

  • 특수문자와 공백은 사용할 수 없다
  • 식별자로 한글을 사용할 수 있다(잘 사용하지 않는다)
  • 키워드는 식별자로 사용할 수 없다
  • 첫번째 문자로 숫자를 사용할 수 없다
  • 길이 제한이 없다
  • 대, 소문자를 구분한다
반응형

'study > JAVA' 카테고리의 다른 글

[JAVA] 메서드 호출  (0) 2023.03.01
[JAVA] 타입 변환  (0) 2023.02.27
[JAVA] 변수 타입과 값 할당  (2) 2023.02.26
반응형

https://www.acmicpc.net/problem/2161

 

2161번: 카드1

N장의 카드가 있다. 각각의 카드는 차례로 1부터 N까지의 번호가 붙어 있으며, 1번 카드가 제일 위에, N번 카드가 제일 아래인 상태로 순서대로 카드가 놓여 있다. 이제 다음과 같은 동작을 카드가

www.acmicpc.net

문제

N장의 카드가 있다. 각각의 카드는 차례로 1부터 N까지의 번호가 붙어 있으며, 1번 카드가 제일 위에, N번 카드가 제일 아래인 상태로 순서대로 카드가 놓여 있다.

이제 다음과 같은 동작을 카드가 한 장 남을 때까지 반복하게 된다. 우선, 제일 위에 있는 카드를 바닥에 버린다. 그 다음, 제일 위에 있는 카드를 제일 아래에 있는 카드 밑으로 옮긴다.

예를 들어 N=4인 경우를 생각해 보자. 카드는 제일 위에서부터 1234 의 순서로 놓여있다. 1을 버리면 234가 남는다. 여기서 2를 제일 아래로 옮기면 342가 된다. 3을 버리면 42가 되고, 4를 밑으로 옮기면 24가 된다. 마지막으로 2를 버리고 나면, 버린 카드들은 순서대로 1 3 2가 되고, 남는 카드는 4가 된다.

N이 주어졌을 때, 버린 카드들을 순서대로 출력하고, 마지막에 남게 되는 카드를 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 정수 N(1 ≤ N ≤ 1,000)이 주어진다.

출력

첫째 줄에 버리는 카드들을 순서대로 출력한다. 제일 마지막에는 남게 되는 카드의 번호를 출력한다.


풀이

가장 앞의 카드를 출력하고 빼주면 되는거라 pop을 사용했다.

앞의 카드를 뒤로 돌릴때도 append와 pop 사용.

순서에 주의하자

코드

# 2161 카드

n = int(input())
card = []

for i in range(1, n+1):
    card.append(i)
while len(card) > 1:
    print(card[0],end=' ')
    card.pop(0)
    card.append(card[0])
    card.pop(0)
print(card[0])
반응형
반응형

https://www.acmicpc.net/problem/1475

 

1475번: 방 번호

첫째 줄에 다솜이의 방 번호 N이 주어진다. N은 1,000,000보다 작거나 같은 자연수이다.

www.acmicpc.net

문제

다솜이는 은진이의 옆집에 새로 이사왔다. 다솜이는 자기 방 번호를 예쁜 플라스틱 숫자로 문에 붙이려고 한다.

다솜이의 옆집에서는 플라스틱 숫자를 한 세트로 판다. 한 세트에는 0번부터 9번까지 숫자가 하나씩 들어있다. 다솜이의 방 번호가 주어졌을 때, 필요한 세트의 개수의 최솟값을 출력하시오. (6은 9를 뒤집어서 이용할 수 있고, 9는 6을 뒤집어서 이용할 수 있다.)

입력

첫째 줄에 다솜이의 방 번호 N이 주어진다. N은 1,000,000보다 작거나 같은 자연수이다.

출력

첫째 줄에 필요한 세트의 개수를 출력한다.


풀이

딕셔너리를 통해서 풀이 하였다.

6과 9는 서로 공유할 수 있기 때문에 입력된 수 안에 있는 경우 둘 다 더해준 후 나중에 2로 나눠 나눠진 값을 ceil로 올림 해줬다

코드

# 1475 방 번호
import math

num = list(input())
sets = {}

for n in num:
    if n in sets:
        if n == '9' or n == '6':
            sets['6'] += 1
            sets['9'] += 1
        else:
            sets[n] += 1
    else:
        if n == '9' or n == '6':
            sets['9'] = 1
            sets['6'] = 1
        else:
            sets[n] = 1

if '6' in sets:
    sets['6'] = math.ceil(sets['6']/2)
if '9' in sets:
    sets['9'] = math.ceil(sets['9']/2)

print(max(sets.values()))
# print(sets)
반응형

+ Recent posts