トップ ライブラリ/Framework/CMS MyBatis MyBatisの使い方 SQL操作 select文 データを全件取得

MySQLからデータを全件取得-MyBatisのSQL操作(select文)

このページでは、MyBatisを使用して、MySQLからselect文でデータを全件取得する方法について記述しています。

▲記事トップへ

このページでは、MyBatisを使用して、MySQLからデータを全件取得する方法について記述しています。

動作環境

サンプルは以下の環境で作成しました。

データベース

MySQLにログインします。

mysql -u root -ppassword

データベース領域(test)を作成します。

mysql> create database test;

テーブル(sample)を作成します。

mysql> CREATE TABLE `sample` (
  `recid` char(5) NOT NULL,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`recid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

データ挿入します。

mysql> INSERT INTO sample VALUES ('00001', 'name1');
mysql> INSERT INTO sample VALUES ('00002', 'name2');
mysql> INSERT INTO sample VALUES ('00003', 'name3');

作成したテーブルとデータは以下の通りになります。

mysql> select * from sample;
+-------+-------+
| recid | name  |
+-------+-------+
| 00001 | name1 |
| 00002 | name2 |
| 00003 | name3 |
+-------+-------+

ソースコード

サンプル実行クラス(SampleMain.java)

package sample;

import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

public class SampleMain {

  public static void main(String[] args) throws IOException {
    InputStream in = Resources.getResourceAsStream("mybatis-config.xml");
    SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);
    SqlSession session = factory.openSession();
    ArrayList<Object> selectList
      = (ArrayList<Object>) session.selectList("selectAll");
    for (Object obj : selectList) {
      if (obj instanceof SampleDto) {
        SampleDto dto = (SampleDto) obj;
        System.out.println(dto.getRecid() + " : " + dto.getName());
      }
    }
  }
}

sampleテーブルのデータ格納用のデータクラス(SampleDto.java)

package sample;

public class SampleDto {
  private String recid;
  private String name;
  public String getRecid() {
    return recid;
  }
  public void setRecid(String recid) {
    this.recid = recid;
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
}

MyBatisの設定

JDBCの設定など全体的な設定(mybatis-config.xml)

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC
"-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url"
value="jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=utf8"/>
<property name="username" value="<ユーザー>"/>
<property name="password" value="<パスワード>"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="sql-mapper.xml"/>
</mappers>
</configuration>

SQLの設定(sql-mapper.xml)

<?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">
<resultMap id="sampleResult" type="sample.SampleDto">
<result property="recid" column="RECID" />
<result property="name" column="NAME" />
</resultMap>
<select id="selectAll" resultMap="sampleResult">
select * from sample;
</select>
</mapper>

アプリの構成

下に以下の構成を作成します。

□任意のフォルダ/
├─bin
│  └─sample
│          SampleDto.class
│          SampleMain.class
│      mybatis-config.xml
│      sql-mapper.xml
└─lib
        mybatis-3.2.3.jar
        mysql-connector-java-5.1.26-bin.jar

動作確認

上記の構成のbinとlibの上までコマンドプロンプトで移動して、以下のようにコマンドを実行します。

CLASSPATH=.\lib\mybatis-3.2.3.jar
CLASSPATH=%CLASSPATH%;.\lib\mysql-connector-java-5.1.26-bin.jar
CLASSPATH=%CLASSPATH%;.\bin;
java -classpath %CLASSPATH% sample.SampleMain
00001 : name1
00002 : name2
00003 : name3

戻る

スポンサーリンク

サイト内のページ

言語
C・C++ /HTML /Java /JavaScript /PHP /シェルスクリプト

開発環境
Ant /Burp /Eclipse /Fiddler /gcc /gdb /Git /g++ /JDK /JMeter /JUnit /Teraterm /ZAP

技術・仕様
Ajax /CORBA /Jakarta EE(旧称J2EE、Java EE) /JNI

ライブラリ/Framework/CMS
bootstrap /jQuery /FuelPHP /Lucene /MyBatis /Seasar2 /Spring /Struts /WordPress

Web API
Google Maps

ITインフラOSとミドルウェア
Linux /Windows /シェル
ActiveMQ /Tomcat /MariaDB /MySQL /Nagios /Redis /Solr

ITインフラサーバー
公開Webサーバー

ITインフラネットワーク
プログラミング /構築

ITインフラセキュリティ
公開サーバーのセキュリティ

PC製品
ZOTAC

SI
ホームページの作り方

その他
IT用語 /ITスキル体系

スポンサーリンク

関連サイト内検索ツール

zealseedsおよび関連サイト内のページが検索できます。

IPアドレス確認ツール

あなたのグローバルIPアドレスは以下です。

18.226.200.44

HTMLの表示色確認ツール

パスワード生成ツール

文字数のプルダウンを選択して、取得ボタンを押すと「a~z、A~Z、0~9」の文字を ランダムに組み合わせた文字列が表示されます。

ここに生成されます。

スポンサーリンク