今天看到mybatis没事就自己弄了弄,由于使用过hibernate,可以发现他两个还是有很多相似的地方的。
废话不多说进入正题:
1.建立项目,现在我建立的项目都是maven的项目,其实只要是java项目都可以的。导入mybatis和mysql包。maven项目如下:
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.45</version>
</dependency>
2.新建mybatis的配置文件我使用eclipse新建的是generatorConfig类型的配置文件,但是我没有使用这种类型的配置文件而是使用了如下的配置文件:
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--数据源 -->
<environments default="user">
<environment id="user">
<!--事务管理方式 -->
<transactionManager type="JDBC"></transactionManager>
<!--数据库连接参数 -->
<dataSource type="POOLED">
<!-- type:数据源连接的方式 ,POOLED:连接池方式, UNPOOLED: 非连接池的方式 ,JNDI:java命名与目录接口方式 -->
<property name="driver" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/user"></property>
<property name="username" value="root"></property>
<property name="password" value="123456"></property>
</dataSource>
</environment>
</environments>
<!-- 引入实体映射文件 -->
<mappers>
<mapper resource="com/mybatis/one/UserMapper.xml" />
</mappers>
</configuration>
3.新建实体类User
package com.mybatis.one;
public class User {
private int id;
private String name;
private String dept;
private String phone;
private String website;
public String getWebsite() {
return website;
}
public void setWebsite(String website) {
this.website = website;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDept() {
return dept;
}
public void setDept(String dept) {
this.dept = dept;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public User(String name, String dept, String phone, String website) {
super();
this.name = name;
this.dept = dept;
this.phone = phone;
this.website = website;
}
public User(){
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", dept=" + dept + ", phone=" + phone + ", website=" + website
+ "]";
}
}
4.新建实体类映射文件UserMapper.xml
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="firstTest">
<!--查询 -->
<!-- 查询需要使用select 标签,id是必须给定的属性,而且要求id是唯一的 resultType 表示结果集类型,就是使用哪个实体类来封装数据
当实体类的属性名和数据库表的字段名一致的时候,能够自动封装 -->
<select id="users" resultType="com.mybatis.one.User">
select
id,name,phone,website,dept from user
</select>
<!--当传入多个参数的时候, 通过parameterType来指定传入参数的类型 引用的多个参数的名字,必须与指定传入类型的属性名一致 -->
<select id="user" parameterType="com.mybatis.one.User"
resultType="com.mybatis.one.User">
select id,name,phone,website,dept from user where
name=#{name} and phone=#{phone}
</select>
<!-- 修改操作 -->
<update id="updateuser" parameterType="com.mybatis.one.User" flushCache="true" statementType="PREPARED" >
update user set name=#{name},phone=#{phone},website=#{website},dept=#{dept}
where id =#{id}
</update>
<!-- 添加操作 -->
<insert id="insertuser" parameterType="com.mybatis.one.User" useGeneratedKeys="true" keyProperty="id" >
insert into user(name,phone,website,dept)
values(#{name},#{phone},#{website},#{dept})
</insert>
<!-- 删除操作 -->
<delete id="deleteuser" parameterType="int" >
delete from user where id=#{id}
</delete>
</mapper>
5.新建测试类Test
package com.mybatis.one;
import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;
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;
/**
* @author Yh
*
*/
public class Test {
public static void main(String[] args) throws IOException {
String resource = "generatorConfig.xml";
Reader reader = null;
SqlSessionFactoryBuilder factoryBuilder = null;
SqlSessionFactory factory = null;
SqlSession sqlSession = null;
try {
// 以字符流的方式读取配置文件
reader = Resources.getResourceAsReader(resource);
// 准备获取工厂对象
factoryBuilder = new SqlSessionFactoryBuilder();
// 得到工厂对象
factory = factoryBuilder.build(reader);
// 获得数据库连接
sqlSession = factory.openSession();
// 查询所有的用户信息 执行查询,传递的参数 是 namespace.id 亲测不用namespace直接使用id也可以
List<User> usersList = sqlSession
.selectList("firstTest.users");
User users = null;
for (User user: usersList) {
System.out.println(user.toString());
users = user;
}
// 进行登录验证
User u = new User();
u.setName("zhangsan");
u.setPhone("1302323322");
User user= sqlSession.selectOne(
"firstTest.user", u);
if(user != null){
System.out.println("存在相对应的数据!");
}else{
System.out.println("不存在相对应的数据!");
}
User d = new User("zhangsan","dsf","1302325322","http://www.baidu.com");
int a = sqlSession.insert("firstTest.insertuser", d);
System.out.println("新增数据返回的值是:"+a);
users.setWebsite("http://www.df.com");
int b = sqlSession.update("updateuser", users);
System.out.println("数据修改后的返回值是:"+b);
int c = sqlSession.delete("deleteuser",2);
System.out.println("删除数据返回的值是:"+c);
// sqlSession.rollback();//如果数据不提交执行事务回滚的话,前面一切没有提交的操作都将回滚。
sqlSession.commit();//如果事物不提交,那么修改、新增、删除操作失效,数据不改变
} catch (IOException e) {
e.printStackTrace();
} finally {
if (sqlSession != null) {
sqlSession.close(); //关闭SqlSession
}
}
}
}
6.我没有配置自动新建表,请自己新建数据库和表。
总结:
SqlSession 中使用selectOne时如果选取的数据有多条,那么将出错。
*********************************有什么问题请留言或者私聊,谢谢!********************************************