mybatis入门第一程序(验证版)

文章展示了MyBatis中的SQL查询界面,包括用户信息查询、插入、删除和更新操作。同时,详细配置了SqlMapConfig环境,包括数据源、事务管理和日志设置。此外,还提及了实体类的定义以及测试类的使用方法。
摘要由CSDN通过智能技术生成
一、SQL查询界面
<?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="com.iotek"> <!--这里使用命名空间是为了减少代码ID重复-->
    <!--这里表示输入参数的映射,即所要查询参数的映射,如果是整形则为int,如果不是整形则不是 parameterType指的是占位符的数据类型,季传茹的数据类型,
    resultTYPE表示结果的数据类型-->
        <select id="getUserById"  parameterType="int" resultType="com.iotek.pojo.User">
       select * from user where id = #{id} <!--这里是用于取参数,问题:如何确定取哪个ID的参数
       因此这样,后面就需要传递一个参数-->
        </select>
       <!--这里配置一个添加元素的程序-->
       <insert id="insertId"  parameterType="com.iotek.pojo.User"><!--这里的ID可以随便写-->
insert into user (username,password,age) values(#{userName},#{password},#{age})<!--配置value的目的就是为了方便从外面传值
这里传是传一个对象,写在上面.这values里面要取对象的属性,所以是#{},#{},#{}-->
<!--#{}:表示一个占位符,可以通过对#号花括号的设置,实现preparedStatedment占位符中传值,自动实行java类型和jdbc类型自动转换
,还可以有效防止SQL注入,#{}可以接收简单类型和pojo属性值,即传入属性就是属性,#{}里面跟的是字段的属性-->
       </insert>
    <!--parameter主要是用于指定要转换的类-->
    <delete id="deleteId" parameterType="com.iotek.pojo.User">
         delete from user where id=#{id}<!--这里用value也可以,ID也可以,简单类型#{},不限制-->
    </delete>
    <!--用于修改的代码-->
    <update id="updateId" parameterType="com.iotek.pojo.User"><!--这里传过来是个对象  -->
    update user set userName=#{userName},password=#{password},age=#{age} where id=#{id}
        </update>
    <!--&{}是表示拼接字符串  -->
            <!--这里新建一个查询-->
            <select id="selectId" parameterType="java.lang.String" resultType="com.iotek.pojo.User"><!--这里时传入的类型   -->
            select * from user where username like "%${id}%" <!--现在也已经支持ID查询  -->
            </select><!--resultType表示传入的是一个集合,默认传入的是对象的属性
                 parameterType是保证传入的值类型,这里是一个字符,所以是String
                 这里是个简单类型所以只能用value
                 现在可以用了-->
</mapper>e

二、SqlMapConfig环境配置以及映射生成界面

<?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/mybatis"/>
                <property name="username" value="root"/>
                <property name="password" value="1234"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
       <!-- <mapper resource="UserMapper.xml"/>-->
        <mapper resource="UserMapper.xml"/>
        <mapper resource="TempMapper.xml"/><!--这个就是把那个配置文件添加进来   -->
    </mappers>
</configuration>

三.log4j.xml界面

# 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

四、实体类一

package com.iotek.pojo;
//和数据库里面的数据一一对应的,就叫持久化对象
/*public class User {
    private int id;
    private String username;// 用户姓名
    private String password;// 性别
    private int age;// 地址
//有参构造
    public User(int id, String username, String password, int age) {
        this.id = id;
        this.username = username;
        this.password = password;
        this.age = age;
    }

实体类二

package com.iotek.pojo;

public class Temp {
    private String id;
    private String name;
    //无参构造
    public Temp() {

    }
    //有参构造
<?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="com.iotek"> <!--这里使用命名空间是为了减少代码ID重复-->
    <!--这里表示输入参数的映射,即所要查询参数的映射,如果是整形则为int,如果不是整形则不是 parameterType指的是占位符的数据类型,季传茹的数据类型,
    resultTYPE表示结果的数据类型-->
        <select id="getUserById"  parameterType="int" resultType="com.iotek.pojo.User">
       select * from user where id = #{id} <!--这里是用于取参数,问题:如何确定取哪个ID的参数
       因此这样,后面就需要传递一个参数-->
        </select>
       <!--这里配置一个添加元素的程序-->
       <insert id="insertId"  parameterType="com.iotek.pojo.User"><!--这里的ID可以随便写-->
insert into user (username,password,age) values(#{userName},#{password},#{age})<!--配置value的目的就是为了方便从外面传值
这里传是传一个对象,写在上面.这values里面要取对象的属性,所以是#{},#{},#{}-->
<!--#{}:表示一个占位符,可以通过对#号花括号的设置,实现preparedStatedment占位符中传值,自动实行java类型和jdbc类型自动转换
,还可以有效防止SQL注入,#{}可以接收简单类型和pojo属性值,即传入属性就是属性,#{}里面跟的是字段的属性-->
       </insert>
    <!--parameter主要是用于指定要转换的类-->
    <delete id="deleteId" parameterType="com.iotek.pojo.User">
         delete from user where id=#{id}<!--这里用value也可以,ID也可以,简单类型#{},不限制-->
    </delete>
    <!--用于修改的代码-->
    <update id="updateId" parameterType="com.iotek.pojo.User"><!--这里传过来是个对象  -->
    update user set userName=#{userName},password=#{password},age=#{age} where id=#{id}
        </update>
    <!--&{}是表示拼接字符串  -->
            <!--这里新建一个查询-->
            <select id="selectId" parameterType="java.lang.String" resultType="com.iotek.pojo.User"><!--这里时传入的类型   -->
            select * from user where username like "%${id}%" <!--现在也已经支持ID查询  -->
            </select><!--resultType表示传入的是一个集合,默认传入的是对象的属性
                 parameterType是保证传入的值类型,这里是一个字符,所以是String
                 这里是个简单类型所以只能用value
                 现在可以用了-->
</mapper>

测试类

package com.pojo;

import com.Goods;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;

import java.io.IOException;
import java.io.InputStream;

public class HomeworkTest {
    @Test
    public void test1() throws IOException
    {
        //输入流
        InputStream inputStream= Resources.getResourceAsStream("SqlMapConfig.xml");
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder=new SqlSessionFactoryBuilder();
        SqlSessionFactory sqlSessionFactory=sqlSessionFactoryBuilder.build(inputStream);//这里不需要加引号,因为是因为io输入流对象
        SqlSession sqlSession=sqlSessionFactory.openSession();
        Goods g=sqlSession.selectOne("main.iotek.selectId",1);//这里是写那个命名空间里面的值
      System.out.println(g);
      sqlSession.commit();
    }
    @Test
    public void test2() throws IOException
    {
        //输入流
        InputStream inputStream= Resources.getResourceAsStream("SqlMapConfig.xml");
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder=new SqlSessionFactoryBuilder();
        SqlSessionFactory sqlSessionFactory=sqlSessionFactoryBuilder.build(inputStream);//这里不需要加引号,因为是因为io输入流对象
        SqlSession sqlSession=sqlSessionFactory.openSession();
        Goods goods=new Goods("weerr","banana",4);//切记主键的唯一性
        int g=sqlSession.insert("main.iotek.insertId",goods);//这里是写那个命名空间里面的值,这里传入的是一个整形
        System.out.println(g);
        sqlSession.commit();
    }
    @Test
    public void test3() throws IOException
    {
        //输入流
        InputStream inputStream= Resources.getResourceAsStream("SqlMapConfig.xml");
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder=new SqlSessionFactoryBuilder();
        SqlSessionFactory sqlSessionFactory=sqlSessionFactoryBuilder.build(inputStream);//这里不需要加引号,因为是因为io输入流对象
        SqlSession sqlSession=sqlSessionFactory.openSession();
        Goods goods=new Goods("weerr","banana",4);//切记主键的唯一性
        int g=sqlSession.update("main.iotek.updateId",goods);//这里是写那个命名空间里面的值,这里传入的是一个对象
        System.out.println(g);
        sqlSession.commit();
    }
    @Test
    public void test4() throws IOException
    {
        //输入流
        InputStream inputStream= Resources.getResourceAsStream("SqlMapConfig.xml");
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder=new SqlSessionFactoryBuilder();
        SqlSessionFactory sqlSessionFactory=sqlSessionFactoryBuilder.build(inputStream);//这里不需要加引号,因为是因为io输入流对象
        SqlSession sqlSession=sqlSessionFactory.openSession();
        //Goods goods=new Goods("weerr","banana",4);//切记主键的唯一性
        //这里是输入影响的行数
        int g=sqlSession.delete("main.iotek.deleteId","wee");//这里是写那个命名空间里面的值,这里传入的是一个对象
        System.out.println(g);
        sqlSession.commit();
    }
}

架包生成界面

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值