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

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

新規登録して質問してみよう
ただいま回答率
85.50%
XML

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

Java

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

Android

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

Q&A

0回答

296閲覧

android でmysqlに接続する

riroholll

総合スコア57

XML

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

Java

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

Android

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

0グッド

0クリップ

投稿2017/11/23 11:04

編集2022/01/12 10:55

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 { } } }

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

イメージ説明

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/11/23 12:58

HTTP経由でつなげてください。
riroholll

2017/11/23 13:01

コードの追加を行いました
退会済みユーザー

退会済みユーザー

2017/11/23 13:13

そのアンドロイド端末が含まれるホスト名の指定でユーザーの作成もしてないんだろうなぁ
riroholll

2017/11/23 13:15

すみません。どう意味でしょうか
退会済みユーザー

退会済みユーザー

2017/11/23 13:20

SELECT Host,User,Db FROM mysql.Db; (つながる場所から確認をどうぞ)
riroholll

2017/11/23 13:25

一応すべての権限を与えています
退会済みユーザー

退会済みユーザー

2017/11/23 13:49

アンドロイドのポートの開放(もしくはパーミッションの開放)と MySQLサーバー側のセキュリティの開放設定は?
riroholll

2017/11/23 13:50

ローカルなのでポートの開放は問題ないと思います
riroholll

2017/11/23 13:51

一応、javaで動作確認をしてからandroidに導入しているのでないと思います。
riroholll

2017/11/23 13:52

一応実機テストとえみゅの確認も行いました
退会済みユーザー

退会済みユーザー

2017/11/23 13:54

アンドロイド(エミュレーター含む)はローカルじゃないです。
退会済みユーザー

退会済みユーザー

2017/11/23 13:54

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

2017/11/23 13:55

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

退会済みユーザー

2017/11/23 14:27

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問