根据下图myBatis的架构,创建一个使用MyBatis的工程。

     

一、配置MyBatis 环境(如图)

1、sqlMapConfig.xml

首先,导入jar包(上图右边)并加载路径,然后在目录下创建一个xml文件 sqlMapConfig.xml , 并添加以下配置代码, 这就是上图架构中的第一步配置mybatis环境,

<?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">
<!-- 使用jdbc事务管理 -->
<transactionManager type="JDBC" />
<!-- 数据库连接池 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url"
value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8" />
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
</environment>
</environments>

2. 配置Mappern.xml

在src目录下创建一个包叫sqlmap, 用来放mappern.xml, 然后在在该包下面创建一个User.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">
<!-- namespace:命名空间,用于隔离sql,还有一个很重要的作用,后面会讲 -->
<mapper namespace="test">

//通过id查询用户
<select id="findUserById" parameterType ="Integer" resultType="mybatis.pojo.User">
select * from user where id = #{v}
</select>

//模糊查询用户
<select id="findUserByUsername" parameterType ="String" resultType="mybatis.pojo.User">
select * from user where username like '%${value}%'
</select> //添加用户

<insert id="insertUser" parameterType ="mybatis.pojo.User">
          insert into user (username,birthday,address,sex)
          values(#{username},#{birthday},#{address},#{sex})
      </insert>

// 更新用户信息

<update id="updateUserById" parameterType="mybatis.pojo.User">
           update user
           set username = #{username},sex = #{sex},birthday = #{birthday},address = #{address}
           where id = #{id}
     </update>

//通过id删除用户

<delete id="deleteUserById" parameterType="Integer">
          delete from user
          where id = #{vvvvv}
      </delete>

</mapper>

3. 然后在src目录下创建log4j.properties用来输出日志,并输入以下信息

# Global logging configuration
log4j.rootLogger=DEBUG, stdout
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

4、在src下创建mybatis.pojo包,并创建User类

package mybatis.pojo;
import java.io.Serializable;
import java.util.Date; public class User implements Serializable { private static final long serialVersionUID = 1L;
private Integer id;
private String username;
private String sex;
private Date birthday;
private String address; public Integer getId() {
return id;
}
//......................................省略

二、 构造SqlSessionFactory、通过SqlSessionFactory创建sqlSession会话、通过sqlSession操作数据库

1、在src目录下创建测试包testpackage和测试文件TesMybatis 并输入以下package testpackageimport mybatis.pojo.User;

import java.io.InputStream;
import java.util.List;
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 TestMybatis { public static void main(String[] args) throws Exception {
testMybatis();
} public static void testMybatis() throws Exception{

//配置mybatis环境配置信息
String resource = "sqlMapConfig.xml";
InputStream in =Resources.getResourceAsStream(resource);

//构造SqlSessionFactory(会话工厂) SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in); //通过SqlSessionFactory创建sqlSession会话

SqlSession sqlSession = sqlSessionFactory.openSession();
        /*
(1)通过用户id查找用户
*/
        User user = sqlSession.selectOne("test.findUserById", "o"); 
System.out.println(user); /*
(2)模糊查询
*/
List<User> users = sqlSession.selectList("test.findUserByUsername", "J");
for(User user2: users){
System.out.println(user2);
} /*
(3)增加用户
*/

User user3 = new User();
          user3.setUsername("Jane");
          user3.setBirthday(new Date());
          user3.setAddress("MountainView");
          user3.setSex("1");
          sqlSession.insert("test.insertUser", user3);
          sqlSession.commit();

/*

(4)更新用户信息

*/        

User user4 = new User();
          user4.setId(10);
          user4.setUsername("Luo");
          user4.setBirthday(new Date());
          user4.setAddress("21811");
          user4.setSex("1");
          sqlSession.update("test.updateUserById", user4);
          sqlSession.commit();

/*

(5)删除用户信息

*/           

sqlSession.delete("test.deleteUserById", 29);
           sqlSession.commit();

    }

}

赞赏码!!!!!!!!!!!!!!!

Mybatis(二)入门程序-通过id查找用户、模糊查找用户、添加用户、删除用户的更多相关文章

  1. mybatis框架入门程序:演示通过mybatis实现数据库的查询操作

    我们现在工程基于的数据库见“https://www.cnblogs.com/wyhluckdog/p/10147754.html”这篇博文. 1.mybatis下载 mybatis的代码由githua ...

  2. 创建表空间、新增用户、给用户赋予DBA权限 、删除用户下的上有数据表

    正文原创 一:查询数据库实例有多少用户: [oracle@localhost ~]$ sqlplus / as sysdba; SQL*Plus: Release 11.2.0.3.0 Product ...

  3. ubuntu 14.04 添加、删除用户,修改用户名称,修改主机名

    ubuntu添加用户 sudo adduser test ubuntu删除用户 sudo userdel test cd /home/ sudo rm -r test

  4. Ansible 从MySQL数据库添加或删除用户

    mysql_user - 从MySQL数据库添加或删除用户. 概要 要求(在执行模块的主机上) 选项 例子 笔记 状态 支持 概要 从MySQL数据库添加或删除用户. 要求(在执行模块的主机上) My ...

  5. 零基础学习java------36---------xml,MyBatis,入门程序,CURD练习(#{}和${}区别,模糊查询,添加本地约束文件) 全局配置文件中常用属性 动态Sql(掌握)

    一. xml  1. 文档的声明 2. 文档的约束,规定了当前文件中有的标签(属性),并且规定了标签层级关系 其叫html文档而言,语法要求更严格,标签成对出现(不是的话会报错) 3. 作用:数据格式 ...

  6. mybatis框架入门程序:演示通过mybatis实现数据库的删除操作

    1.mybatis的基本配置工作可以在我的这篇博客中查看:https://www.cnblogs.com/wyhluckdog/p/10149480.html 2.删除用户的映射文件: <!-- ...

  7. 添加用户useradd,给用户设置修改密码passwd,修改用户信息usermod,修改用户密码状态chage,删除用户userdel,查询用户及组id,切换用户su,查看当前环境变量env

    useradd 用户名 passwd 用户名,给指定用户设密码 passwd给当前用户设密码 添加一个用户系统会自动在以下文件或目录创建对应用户信息: [root@localhost ~]# grep ...

  8. 无责任Windows Azure SDK .NET开发入门篇三[使用Azure AD 管理用户信息--3.5 Delete删除用户]

    3.5 Delete删除用户 删除也是通过ObjectID获得对象进行删除 [Authorize] public async Task<ActionResult> Delete(strin ...

  9. Linux命令之useradd和userdel(添加、删除用户)

    一.[useradd]:添加用户命令 1.作用 useradd或adduser命令用来建立用户帐号和创建用户的起始目录,使用权限是超级用户. 2.格式 useradd [-d home] [-s sh ...

随机推荐

  1. TreeView CheckBox勾选联动

    http://www.cnblogs.com/excellently/p/TreeViewCheckBox.html 在C# Winform项目中用到了TreeView控件,并且需要勾选的功能.父子节 ...

  2. bfs退出条件

    找到结果即退出? Possibly Not! 如拓展(x)将导致距离增加0(x)或1(x+1),[这种情况用优先队列] 那么该拓展得到的结果也许并不是最优的,后面还有x. 所以最好的是遍历(不知怎么说 ...

  3. re-download dependencies and 无法下载jar 的解决

    Re-download dependencies and sync project (requires network) 其实就是修改gradle 的path 路径:

  4. Luogu P4097 [HEOI2013]Segment 李超线段树

    题目链接 \(Click\) \(Here\) 李超线段树的模板.但是因为我实在太\(Naive\)了,想象不到实现方法. 看代码就能懂的东西,放在这里用于复习. #include <bits/ ...

  5. vue(基础二)_组件,过滤器,具名插槽

    一.前言 主要包括:  1.组件(全局组件和局部组件)                     2.父组件和子组件之间的通信(单层)                     3.插槽和具名插槽     ...

  6. python3: 爬虫---- urllib, beautifulsoup

    最近晚上学习爬虫,首先从基本的开始: python3 将urllib,urllib2集成到urllib中了, urllib可以对指定的网页进行请求下载,  beautifulsoup 可以从杂乱的ht ...

  7. 1.1实战项目:电影周周看V1(初识小程序)

    第一小程序的实战项目: 覆盖的小程序技术: 讲解方式: 学习方法:

  8. Go-day06

    今日内容概要: 1.interface接口 2.反射 一.接口 接口定义 1.Interface类型可以定义一组方法,当时不需要实现,并且interface不能包含任何变量 2.接口定义 type e ...

  9. 20165232第4次实验《Android程序设计》实验报告

    20165232第4次实验<Android程序设计>实验报告 一.实验报告封面 一.实验报告封面 课程:Java程序设计 班级:1652班 姓名:何彦达 学号:20165232 指导教师: ...

  10. 1、JPA-HelloWorld

    /** * JPA 是 hibernate 的一个抽象(就像JDBC和JDBC驱动的关系) * JPA 本质上是一种 ORM 规范,不是 ORM 框架,因为 JPA 并未提供 ORM 实现,只是制订了 ...