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

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

ただいまの
回答率

90.33%

  • Java

    14431questions

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

  • MySQL

    6183questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • JSP

    960questions

    JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

javaからMysqlに更新の処理を行いたい

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 1,793

manmos

score 47

javaからMysqlを操作するやり方について質問です。

現在jspの入力フォームに入力した情報を使ってMysqlへ登録、更新の処理を行うコードを作成中なのですが、登録の処理を行うコードは完成したのですが更新の処理の書き方がよくわかりません。
Mysqlに直接sql文を入力し更新することはできるのですがこれをjavaでやろうとするところで躓いてます。
登録(insert)の処理はjsp→servlet→Daoと値を受け渡して下記のように行っています。

public void InsertInformation(String name,
            String name_hiragana, String birthday, String sex,
            String mail_address, String telephone_number,
            String company_info_id, String business_maneger, String department,
            String commissioning_status) throws ClassNotFoundException, SQLException {
        // SQL文
        String sql = "INSERT INTO employee_info (name, name_hiragana, birthday, sex, mail_address, telephone_number, company_info_id, business_maneger, department, commissioning_status) values(?, ?, cast(? as date), ?, ?, ?, ?, ?, ?, ?)";

        try {
            Class.forName("com.mysql.jdbc.Driver"); // ドライバクラスのロード

            conn = DriverManager.getConnection(url, user, password); // Connectionクラス生成
            pstmt = conn.prepareStatement(sql); // PreparedStatementクラス生成

            pstmt.setString(1, name);
            pstmt.setString(2, name_hiragana);
            pstmt.setString(3, birthday);
            pstmt.setString(4, sex);
            pstmt.setString(5, mail_address);
            pstmt.setString(6, telephone_number);
            pstmt.setString(7, company_info_id);
            pstmt.setString(8, business_maneger);
            pstmt.setString(9, department);
            pstmt.setString(10, commissioning_status);
            pstmt.executeUpdate();

            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
        } finally {
            // 終了処理
            // PreparedStatement終了
            if (pstmt != null) {
                try {
                    pstmt.close();
                } catch (SQLException e) {
                }
                pstmt = null;
            }
            // Connection終了
            if (conn != null) {
                try {
                    conn.close();
                } catch (SQLException e) {
                }
                conn = null;
            }
        }
    }


更新(update)の際は、登録の際に自動採番で割り振られるidをwhere句に当てはめて行います。
上記のInsertの処理をUpdateに置き換えて書くとどのようになるでしょうか?

どうかご教授お願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

+1

時間が経っているご質問なので解決してたらごめんなさい。

単純にUPDATEに置き換えてあげれば良いかと思います。

<宣言部は省略>
    // SQL文
    String sql = "UPDATE employee_info SET name=?, name_hiragana=?, birthday=cast(? as date), sex=?, mail_address=?, telephone_number=?, company_info_id=?, business_maneger=?, department=?, commissioning_status=? where id=?";

    try {
        Class.forName("com.mysql.jdbc.Driver"); // ドライバクラスのロード

        conn = DriverManager.getConnection(url, user, password); // Connectionクラス生成
        pstmt = conn.prepareStatement(sql); // PreparedStatementクラス生成

        pstmt.setString(1, name);
        pstmt.setString(2, name_hiragana);
        pstmt.setString(3, birthday);
        pstmt.setString(4, sex);
        pstmt.setString(5, mail_address);
        pstmt.setString(6, telephone_number);
        pstmt.setString(7, company_info_id);
        pstmt.setString(8, business_maneger);
        pstmt.setString(9, department);
        pstmt.setString(10, commissioning_status);
        pstmt.setString(11, id); // 追加
        int cnt = pstmt.executeUpdate();

        <更新結果で何かする場合はcntの値を使用する>

        conn.close();
    <例外処理は省略>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • Java

    14431questions

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

  • MySQL

    6183questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • JSP

    960questions

    JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。