* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
Window10 64bit |
|
[cubrid_rel] 수행 결과 | |
[도움말]-[버전정보] 확인 | |
android studio |
* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 | 재현 가능한 Source와 SQL |
관련 테이블(인덱스, 키정보 포함) 정보 | CUBRID 홈 디렉토리 아래 log 디렉토리 압축 |
-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
q&a 찾다보니 어떤 분이 올려주신 다음과 같은 코드가 있어서 실행해보았습니다.
package com.example.cse.dbcubrid;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import android.app.*;
import android.util.*;
public class MainActivity extends Activity{
Button btn;
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
c();
btn = (Button) findViewById(R.id.btn_test);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
s();
}
});
}
void c() {
try {
Class.forName("cubrid.jdbc.driver.CUBRIDDriver");
conn = DriverManager
.getConnection(
"jdbc:cubrid:localhost:30000:demodb:::?charset=UTF-8",
"dba", "");
conn.setAutoCommit(false);
} catch (Exception e) {
e.printStackTrace();
}
}
void s() {
try {
String sql = "select f_name from code";
stmt = conn.createStatement();
rs = stmt.executeQuery(sql);
while (rs.next()) {
Log.e("rs.getString(1)", "" + rs.getString(1));
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
07-18 07:09:33.859 3524-3524/? W/System.err﹕ android.os.NetworkOnMainThreadException 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1147) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at java.net.InetAddress.lookupHostByName(InetAddress.java:418) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at java.net.InetAddress.getAllByNameImpl(InetAddress.java:252) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at java.net.InetAddress.getByName(InetAddress.java:305) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at java.net.InetSocketAddress.<init>(InetSocketAddress.java:105) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at java.net.InetSocketAddress.<init>(InetSocketAddress.java:90) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at cubrid.jdbc.net.BrokerHandler.connectBroker(BrokerHandler.java:28) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at cubrid.jdbc.jci.UConnection.reconnectWorker(UConnection.java:1822) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at cubrid.jdbc.jci.UConnection.reconnect(UConnection.java:1923) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at cubrid.jdbc.jci.UConnection.checkReconnect(UConnection.java:2095) 07-18 07:09:33.859 3524-3524/? W/System.err﹕ at cubrid.jdbc.jci.UConnection.tryConnect(UConnection.java:329) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at cubrid.jdbc.driver.CUBRIDDriver.connect(CUBRIDDriver.java:241) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at java.sql.DriverManager.getConnection(DriverManager.java:179) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at java.sql.DriverManager.getConnection(DriverManager.java:213) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at com.example.cse.dbcubrid.MainActivity.c(MainActivity.java:48) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at com.example.cse.dbcubrid.MainActivity.onCreate(MainActivity.java:32) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.app.Activity.performCreate(Activity.java:5990) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2390) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.app.ActivityThread.access$800(ActivityThread.java:151) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.os.Handler.dispatchMessage(Handler.java:102) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.os.Looper.loop(Looper.java:135) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at android.app.ActivityThread.main(ActivityThread.java:5257) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at java.lang.reflect.Method.invoke(Native Method) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at java.lang.reflect.Method.invoke(Method.java:372) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 07-18 07:09:33.860 3524-3524/? W/System.err﹕ at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
과 같은 에러가 발생합니다.
어떤 부분을 수정해야할까요??? 안드로이드 연동은 자료가 많이 없어서 하는게 너무 힘드네요ㅠㅠㅠ
참고로 에러 로그에 MainActivity.java:48은 conn = DriverManager.getConnection("jdbc:cubrid:localhost:30000:demodb:::?charset=UTF-8","dba", ""); 이거구요.
MainActivity.java:32는 c();입니다.
코드를 보면, connection string내에 cubrid가 동작하는 서버인 localhost로 되어 있습니다. (사용하시는 장비가 안드로이드이면, cubrid를 안드로이드에 구동하지 않을 것 같습니다.)
cubrid가 구동되는 ip address를 넣으시고 다시 한번 시도 해보세요.
예를들어서, cubrid가 동작하는 서버의 ip가 192.0.0.1 이면 다음과 같이 해 보세요.
"jdbc:cubrid:192.0.0.1:30000:demodb:::?charset=UTF-8",