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

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

ただいまの
回答率

87.37%

SqlSessionで複数Insertをしたいです

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 2,572

score 8

解決したいこと
・SqlSessionで複数Insertをしたい

public static void main(String[] args) throws Exception {
            try (InputStream in = MyBatis_Select.class.getResourceAsStream("/mybatis-config.xml")) {
                SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);
                try (SqlSession session = factory.openSession()) {
                    session.insert("sample.mybatis.insertTest2","Test_NO", "Test_Name", "Test_Name_Read", "Test_Code");
                    session.commit();
                    session.close();
                }
            }
     }


上記のようにsession.insertの引数に複数値を入力すると、eclipse上で
「型 SqlSession のメソッド insert(String, Object) は引数 (String, String, String, String, String) に適用できません」
とエラーが表示されます。

session.insert("sample.mybatis.insertTest2","Test_NO");
と、引数を一つにするとエラーが出ずDBにInsertしてくれました。

どのようにすれば複数の値をInsertできるでしょうか。
それと上記のエラーの意味も解説してくださるとありがたいです。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="sample.mybatis">
  <insert id="insertTest2">
  insert into test(EmployeeNo, FullName, FullName_Read, CompanyCode)
  values(#{EmployeeNo}, #{FullName}, #{FullName_Read}, #{CompanyCode});
  </insert>
</mapper>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

0

「型 SqlSession のメソッド insert(String, Object) は引数 (String, String, String, String, String) に適用できません」
というエラーメッセージは、

・型 SqlSession のinsertメソッドは、(string型 と Object型)二つの引数を持ちます。

・” session.insert("sample.mybatis.insertTest2","Test_NO", "Test_Name", "Test_Name_Read", "Test_Code");” の箇所で、insertメソッドの引数が5つのString型 (String, String, String, String, String) になっていますが、この引数を(string型 と Object型)二つの引数に適応することは出来ないです。

という事です。(ぶっちゃけ、insertメソッドの使い方が間違っているという指摘ですね)

複数のInsertをしたいのであれば、insertメソッドを複数回実行してください。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/10/10 10:56

    回答ありがとうございます。

    session.insert("sample.mybatis.insertTes2", "Test_NO");
    session.insert("sample.mybatis.insertTes2","Test_Name");
    ~
    session.commit();
    session.close();

    とinsertメソッドを複数回に分けて書いたのですが、Insertできませんでした。
    複数回というのは上記のような書き方で合っているでしょうか?

    キャンセル

  • 2019/10/10 11:54

    insertは、データベースにデータを追加するものです。
    データベースに格納されている各データには、他のデータと区別できるように特有の名前(主キー)が付けられます。
    日本国民に割り当てられた特有の番号であるマイナンバーのようなものが、データベースに有ると考えて戴くと判りやすいかもしれません。

    insert関数の第1引数(文字列)には、主キーを指定します。
    主キーは他のデータのキーと重複してはいけませんから、既にデータベースで使われている主キーを第1引数にするとinsertは失敗します。

    初めてのinsert
    session.insert("sample.mybatis.insertTes2", "Test_NO");
    は成功するでしょうが、
    session.insert("sample.mybatis.insertTes2","Test_Name");以降の、主キーを"sample.mybatis.insertTes2"にしたinsertは全て失敗するはずで、その旨のエラーメッセージが表示されたのではないかと思います。

    複数のinsertをするには、それぞれ別の主キーを使わなければなりません。同じ主キーを使ってinsertしているから、insertできないのです。

    session.insert("sample.mybatis.insertTes2", "Test_NO");
    session.insert("sample.mybatis.insertTes3“,"Test_Name");
    であれば、主キーが異なるので成功するはずです。
    (一度 insertすると、そのデータはデータベースに残りますから、同じ引数のinsertを再実行するとinsertは失敗します)

    キャンセル

0

SqlSessionTemplate.insert()メソッドは、insert("sqlのid", 変数を格納するオブジェクト) が正しいです。

さてSQLの定義を見てみると

values(#{EmployeeNo}, #{FullName}, #{FullName_Read}, #{CompanyCode})


と書かれていますから、安易なのはjava.util.HashMapを用意して、キーと値を設定すれば良いです。

ちなみに、MyBatisは変数に格納したオブジェクトのフィールド名を自動的に解決する機能があるので、HashMapでなくとも任意のJavaクラスのフィールドも利用できます。その時、Javano先頭を大文字にしません。

書くならば、次のようにします。

sqlSessionTemplate.insert("sql-id", sampleValueObject);
class SampleValueObject {
  private Long employeeNo;
  private String fullName;
  private String fuuNameRead;
  private Long companyCode;
  // get・setメソッドは省略 
}
values(#{employeeNo}, #{fullName}, #{fullNameRead}, #{companyCode})

その他文法やその他詳細な記述方法については、公式サイトを参照するのが一番簡単にして、確実な方法でしょう。
https://mybatis.org/mybatis-3/ja/dynamic-sql.html

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

  • ただいまの回答率 87.37%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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