質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

91.37%

  • Java

    10440questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • Android

    5151questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • XML

    525questions

    XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

android でmysqlに接続する

受付中

回答 0

投稿 2017/11/23 20:04 ・編集 2017/11/23 22:24

  • 評価
  • クリップ 1
  • VIEW 95

riro0704

score 23

androidでmysqlに接続したいと思いこのようなコードを書いていました。

package com.example.askad.sql;



import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import java.sql.Connection;

public class MainActivity extends AppCompatActivity {

    int user_id=100;
    String user_name = "genkin";
    String kamoku     = "genkin";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        try {
            // ト゛ライハ゛ロート゛
            Class.forName("com.mysql.jdbc.Driver");





            // MySQL に接続
            Connection con = DriverManager.getConnection("jdbc:mysql://192.168.10.8:3306/testdb", "test11", "");

            // ステートメント生成
            Statement stmt = con.createStatement();




//SQL を実行



            String insert  = "insert into test_table(user_id,user_name,kamoku) values  (" + user_id + ","  +  "'" +user_name+  "'" + "," + "'" + kamoku + "'"  + ")";
            //String sqlStr = "insert into test_table(user_id,user_name) values(2,'satou');";
            stmt.executeUpdate(insert);





            // 接続を閉し゛る
            stmt.close();
            con.close();



        }catch (Exception e){

            e.printStackTrace() ;

        }finally {

        }
    }
}


このようにコードを構築してみました。
イメージ説明

すると

Error:(29, 30) エラー: シンボルを見つけられません
シンボル:   変数 DriverManager
場所: クラス MainActivity

Error:(32, 13) エラー: シンボルを見つけられません
シンボル:   クラス Statement
場所: クラス MainActivity

このようにエラーが出ました。

どのように対処すればよいでしょうか。
回答よろしくお願いします。

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Toast;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class MainActivity extends AppCompatActivity {


    int user_id=100;

    String user_name = "genkin";

    String kamoku     = "genkin";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        try {
            // ト゛ライハ゛ロート゛
            Class.forName("com.mysql.jdbc.Driver");





            // MySQL に接続
            Connection con = DriverManager.getConnection("jdbc:mysql://192.168.10.8:3306/testdb", "test11", "");

            // ステートメント生成
            Statement stmt = con.createStatement();




//SQL を実行



            String insert  = "insert into test_table(user_id,user_name,kamoku) values  (" + user_id + ","  +  "'" +user_name+  "'" + "," + "'" + kamoku + "'"  + ")";
            //String sqlStr = "insert into test_table(user_id,user_name) values(2,'satou');";
            stmt.executeUpdate(insert);





            // 接続を閉し゛る
            stmt.close();
            con.close();



        }catch (Exception e){

            e.printStackTrace() ;

        }finally {

        }
    }
}

このようにコードの変更をしエラーはなくなりましたが
やはりデータを追加することができません

イメージ説明

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正の依頼

  • asahina1979

    2017/11/23 22:54

    アンドロイド(実機)は言わずともわかるでしょうがこれもローカルじゃないです。

    キャンセル

  • riro0704

    2017/11/23 22:55

    ルータに接続する場合、ゲートウェイはサーバ側と同じではないのでしょうか?

    キャンセル

  • asahina1979

    2017/11/23 23:27

    前回の質問と同じLAN内ということね。そうするとAndroid側のSecurity問題でしょうね

    キャンセル

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

ただいまの回答率

91.37%

関連した質問

同じタグがついた質問を見る

  • Java

    10440questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • Android

    5151questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • XML

    525questions

    XMLは仕様の1つで、マークアップ言語群を構築するために使われています。