一、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(); } }
架包生成界面