在使用模糊查詢sql時,若是使用${}進行字符拼接,沒法防止sql諸如問題,若是使用concat函數則只對mysql有效果,用Oracle則須要用鏈接符||,這樣在數據庫變的時候須要修改,不利於移植。mybatis提供元素<bind>很好能解決這個問題。java
項目結構:mysql
廢話不說,使用maven管理jar,以下:sql
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.example</groupId> <artifactId>maven</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>maven</name> <url>http://maven.apache.org</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> </properties> <dependencies> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.2</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.2</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.40</version> </dependency> </dependencies> </project>
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> <properties resource="resoures/db.properties" /> <!--1.配置環境 ,默認的環境id爲mysql --> <environments default="mysql"> <!--1.2.配置id爲mysql的數據庫環境 --> <environment id="mysql"> <!-- 使用JDBC的事務管理 --> <transactionManager type="JDBC" /> <!--數據庫鏈接池 --> <dataSource type="POOLED"> <!-- 數據庫驅動 --> <property name="driver" value="${jdbc.driver}" /> <!-- 鏈接數據庫的url --> <property name="url" value="${jdbc.url}" /> <!-- 鏈接數據庫的用戶名 --> <property name="username" value="${jdbc.username}" /> <!-- 鏈接數據庫的密碼 --> <property name="password" value="${jdbc.password}" /> </dataSource> </environment> </environments> <!--2.配置Mapper的位置 --> <mappers> <mapper resource="com/example/test/mybatis/mapper/UserMapper.xml" /> </mappers> </configuration>
數據庫配置:apache
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis
jdbc.username=root
jdbc.password=root
PS:注意配置文件的位置!session
三種方法實現:mybatis
數據庫表格結構app
javabeanmaven
package com.example.test.mybatis; public class User { private String name; private String sex; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "User [name=" + name + ", sex=" + sex + ", age=" + age + "]"; } }
session工具類:ide
package com.example.test.mybatis; import java.io.Reader; 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 MybatisUtils { private static SqlSessionFactory sqlSessionFactory = null; // 初始化SqlSessionFactory對象 static { try { // 使用MyBatis提供的Resources類加載mybatis的配置文件 Reader reader = Resources.getResourceAsReader("resoures/mybatis-config.xml"); // 構建sqlSession的工廠 sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader); } catch (Exception e) { e.printStackTrace(); } } // 獲取SqlSession對象的靜態方法 public static SqlSession getSession() { return sqlSessionFactory.openSession(); } }
mapper文件
方法一:_parameter.getName()傳參,注意參數類型爲javabean User
<?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.example.test.mybatis.mapper.UserMapper"> <select id="findUserByName" parameterType="com.example.test.mybatis.User" resultType="com.example.test.mybatis.User"> <!--_parameter.getUsername()也可直接寫成傳入的字段屬性名,即username --> <bind name="pattern" value="'%'+_parameter.getName()+'%'" /> select * from user where name like #{pattern} </select> </mapper>
測試方式:
package com.example.test.mybatis; import java.util.List; import org.apache.ibatis.session.SqlSession; public class MybatisTest { public static void main(String[] args) { SqlSession session = MybatisUtils.getSession(); User user = new User(); user.setName("s"); List<User> list = session.selectList("com.example.test.mybatis.mapper.UserMapper.findUserByName",user); for (User u : list) { System.out.println(u); } session.close(); } }
測試結果:User [name=as, sex=男, age=1]
方法二:直接使用_parameter傳參,注意傳入的參數類型是String name
<?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.example.test.mybatis.mapper.UserMapper"> <select id="findUserByStrName" parameterType="String" resultType="com.example.test.mybatis.User"> <!--_parameter.getUsername()也可直接寫成傳入的字段屬性名,即username --> <bind name="username" value="'%'+_parameter+'%'" /> select * from user where name like #{username} </select> </mapper>
對應測試方法:
package com.example.test.mybatis; import java.util.List; import org.apache.ibatis.session.SqlSession; public class MybatisTest { public static void main(String[] args) { SqlSession session = MybatisUtils.getSession(); String name = "aa"; List<User> list = session.selectList("com.example.test.mybatis.mapper.UserMapper.findUserByStrName",name); for (User u : list) { System.out.println(u); } session.close(); } }
測試結果:
User [name=aa, sex=男, age=10]
User [name=aaad, sex=男, age=11]
方法三:直接用javabean的屬性傳參,注意參數類型是javabean User
<?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.example.test.mybatis.mapper.UserMapper"> <select id="findUserByParameterName" parameterType="com.example.test.mybatis.User" resultType="com.example.test.mybatis.User"> <!--_parameter.getUsername()也可直接寫成傳入的字段屬性名,即name --> <bind name="username" value="'%'+name+'%'" /> select * from user where name like #{username} </select> </mapper>
package com.example.test.mybatis; import java.util.List; import org.apache.ibatis.session.SqlSession; public class MybatisTest { public static void main(String[] args) { SqlSession session = MybatisUtils.getSession(); User user = new User(); user.setName("aa"); List<User> list = session.selectList("com.example.test.mybatis.mapper.UserMapper.findUserByParameterName",user); for (User u : list) { System.out.println(u); } session.close(); } }
測試結果:
User [name=aa, sex=男, age=10]User [name=aaad, sex=男, age=11]