MyBatis知多少(20)MyBatis读取操作
上篇展示了如何使用MyBatis执行创建操作表。本章将告诉你如何使用MyBatis来读取表。
我们已经在MySQL下有EMPLOYEE表:
- CREATE TABLE EMPLOYEE (
- id INT NOT NULL auto_increment,
- first_name VARCHAR(20) default NULL,
- last_name VARCHAR(20) default NULL,
- salary INT default NULL,
- PRIMARY KEY (id)
- );
此表有如下只有一条记录:
- mysql> select * from EMPLOYEE;
- +----+------------+-----------+--------+
- | id | first_name | last_name | salary |
- +----+------------+-----------+--------+
- | 1 | Zara | Ali | 5000 |
- +----+------------+-----------+--------+
- 1 row in set (0.00 sec)
Employee POJO 类:
要执行读操作,我们将修改Employee类中Employee.java文件,如下所示:
- public class Employee {
- private int id;
- private String first_name;
- private String last_name;
- private int salary;
- /* Define constructors for the Employee class. */
- public Employee() {}
- public Employee(String fname, String lname, int salary) {
- this.first_name = fname;
- this.last_name = lname;
- this.salary = salary;
- }
- /* Here are the method definitions */
- public int getId() {
- return id;
- }
- public String getFirstName() {
- return first_name;
- }
- public String getLastName() {
- return last_name;
- }
- public int getSalary() {
- return salary;
- }
- } /* End of Employee */
Employee.xml 文件:
要定义使用iBATIS SQL映射语句,我们将增加<select>标记在Employee.xml文件,这个标签定义中,我们会定义将用于在IbatisRead.java文件的数据库执行SQL SELECT查询的“id”。
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE sqlMap
- PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"
- "http://ibatis.apache.org/dtd/sql-map-2.dtd">
- <sqlMap namespace="Employee">
- <insert id="insert" parameterClass="Employee">
- INSERT INTO EMPLOYEE(first_name, last_name, salary)
- values (#first_name#, #last_name#, #salary#)
- <selectKey resultClass="int" keyProperty="id">
- select last_insert_id() as id
- </selectKey>
- </insert>
- <select id="getAll" resultClass="Employee">
- SELECT * FROM EMPLOYEE
- </select>
- </sqlMap>
在这里,我们没有使用WHERE子句和SQL SELECT语句。后续章节将演示如何用WHERE和SELECT语句子句,以及如何将值传递到WHERE子句。
IbatisRead.java 文件:
该文件将应用程序级别的逻辑从雇员Employee表中读出记录:
- import com.ibatis.common.resources.Resources;
- import com.ibatis.sqlmap.client.SqlMapClient;
- import com.ibatis.sqlmap.client.SqlMapClientBuilder;
- import java.io.*;
- import java.sql.SQLException;
- import java.util.*;
- public class IbatisRead{
- public static void main(String[] args)
- throws IOException,SQLException{
- Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
- SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);
- /* This would read all records from the Employee table. */
- System.out.println("Going to read records.....");
- List <Employee> ems = (List<Employee>)
- smc.queryForList("Employee.getAll", null);
- Employee em = null;
- for (Employee e : ems) {
- System.out.print(" " + e.getId());
- System.out.print(" " + e.getFirstName());
- System.out.print(" " + e.getLastName());
- System.out.print(" " + e.getSalary());
- em = e;
- System.out.println("");
- }
- System.out.println("Records Read Successfully ");
- }
- }
编译和运行:
下面是步骤来编译并运行上述应用。请确保您已在进行的编译和执行之前,适当地设置PATH和CLASSPATH。
创建Employee.xml如上所示。
创建Employee.java如上图所示,并编译它。
创建IbatisRead.java如上图所示,并编译它。
执行IbatisRead二进制文件来运行程序。
你会得到下面的结果,并且将记录从EMPLOYEE表中读取。
- Going to read records.....
- 1 Zara Ali 5000
- Record Reads Successfully
系列文章:
MyBatis知多少(13)MyBatis如何解决数据库的常见问题
MyBatis知多少(20)MyBatis读取操作的更多相关文章
- Python小白需要知道的 20 个骚操作!
Python小白需要知道的 20 个骚操作! Python 是一个解释型语言,可读性与易用性让它越来越热门.正如 Python 之禅中所述: 优美胜于丑陋,明了胜于晦涩. 在你的日常编码中,以下技巧可 ...
- Python 必知的 20 个骚操作!
以下为译文: Python 是一个解释型语言,可读性与易用性让它越来越热门. 正如 Python 之禅中所述: 优美胜于丑陋,明了胜于晦涩. 在你的日常编码中,以下技巧可以给你带来意想不到的收获. ...
- MyBatis知多少(22)MyBatis删除操作
本节从表中使用MyBatis删除记录. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( id INT NOT NULL auto_increment, f ...
- MyBatis知多少(21)更新操作
上一章展示了如何使用MyBatis对表进行读取操作.本章将告诉你如何在一个表中使用MyBatis更新记录. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( ...
- MyBatis知多少(19)MyBatis操作
若要使用iBATIS执行的任何CRUD(创建,写入,更新和删除)操作,需要创建一个的POJO(普通Java对象)类对应的表.本课程介绍的对象,将“模式”的数据库表中的行. POJO类必须实现所有执行所 ...
- MyBatis知多少(26)MyBatis和Hibernate区别
iBatis和Hibernate之间有着较大的差异,但两者解决方案很好,因为他们有特定的领域.我个人建议使用MyBatis的,如果: 你想创建自己的SQL,并愿意维持他们. 你的环境是由关系数据模型驱 ...
- MyBatis知多少(26)调试
这是很容易,同时与iBATIS的工作程序进行调试. iBATIS有内置的日志支持,并适用于下列日志库,并在这个顺序搜索他们. Jakarta Commons日志记录(JCL). Log4J JDK 日 ...
- MyBatis知多少(25)动态SQL
使用动态查询是MyBatis一个非常强大的功能.有时你已经改变WHERE子句条件的基础上你的参数对象的状态.在这种情况下的MyBatis提供了一组可以映射语句中使用,以提高SQL语句的重用性和灵活性的 ...
- MyBatis知多少(24)存储过程
使用MyBatis配置来调用存储过程.为了理解这一章,首先需要了解我们是如何在MySQL中创建一个存储过程. 在继续对本节学习之前,可以自行学习MySQL存储过程. 我们已经在MySQL下有EMPLO ...
随机推荐
- Cocoa编程开发者手册
Cocoa编程开发者手册(Objective-C权威著作超一流翻译阵容) [美] 奇斯纳尔(Chisnall,D.) 著 霍炬等 译 ISBN 978-7-121-12239-2 2013年7月出版 ...
- Leetcode 345 Reverse Vowels of a String 字符串处理
题意:倒置字符串中的元音字母. 用两个下标分别指向前后两个相对的元音字母,然后交换. 注意:元音字母是aeiouAEIOU. class Solution { public: bool isVowel ...
- Leetcode 290 Word Pattern STL
Leetcode 205 Isomorphic Strings的进阶版 这次是词组字符串和匹配字符串相比较是否一致 请使用map来完成模式统计 class Solution { public: boo ...
- PHP实现微信公众账号开发
1.首先需要一个可以外网访问的接口url. 我这里是申请的新浪免费云服务器,http://xxxxx.applinzi.com/wx.php,具体自己可以去新浪云中心申请地址为:http://www. ...
- UIScrollView offset in UINavigationController
转:UIScrollView offset in UINavigationController 通过设置viewCtronller的 self.automaticallyAdjustsScrollVi ...
- zz 游戏程序员的学习之路(中文版)
游戏程序员的学习之路(中文版) Milo Yip · 1 天前 感谢 @楚天阔(tkchu)编写脚本及整理中文译本数据,自动从英文版生成中文版,SVG / PDF 版本中的书籍图片现在链接至豆瓣页面. ...
- jxl 2.6.12 与 jxl 2.3.0 稳定版性能比较
jxl 2.3.0 org.jxls:jxls:2.3.0 org.jxls:jxls-poi:1.0.9 org.jxls:jxls-jexcel:1.0.6 jxls-reader:2.0.2 j ...
- 如何查看Linux的系统是64位的还是32位的
可以用命令“getconf LONG_BIT”查看,如果返回的结果是32则说明是32位,返回的结果是64则说明是64位. 此外还可以使用命令“uname -a”查看,输出的结果中,如果有x86_64就 ...
- (转)create table #temptable 临时表 和 declare @bianliang table ()表变量
在开发过程中,经常会遇到使用表变量和本地临时表的情况.下面是对二者的一个介绍: 1. 为什么要使用表变量 表变量是从2000开始引入的,微软认为与本地临时表相比,表变量具有如下优点: a.与其他变量 ...
- windows 2003服务器网络异常流量的处理办法
最近通过防火墙发现一台服务器的流量占用非常厉害,上传的流量每秒达到100—200Mb/s,几乎占掉了一半的带宽.本来那台服务器上安装了360安全卫士,360安全卫士自身带的网络防火墙只能看进程,而不能 ...