-
不仅可以判断参数,还可以判断_parameter和_databasedId
-
bind标签
-
sql标签配合include标签完成对重复sql语句的抽取
-
要在带注解的映射器接口类中使用动态 SQL,可以使用 script 元素
-
缓存
-
- 一级缓存
-
- 一级缓存失效情况
-
- 手动清空缓冲的函数:
-
二级缓存: namespace级别的缓存,隔一段时间会自动刷新缓存
-
- 只有在sqlSession关闭或提交后,才会把数据从一级缓存中,搬家来到二级缓存
-
第一步:配置文件中开启二级缓存
-
第二步:在需要使用二级缓存的映射文件中使用cache配置缓存
-
第三步: POJO对象需要实现序列化接口
-
二级缓存cache标签里面的相关属性
-
缓存的查询顺序
-
缓存原理----每一个dao有他自己的二级缓存
-
缓存有关的设置
-
整合第三方缓存—这里整合ehcache—java进程内的缓存框架
-
- 1.导入依赖
-
2.ehcache要工作需要一个配置文件,文件名叫ehcache.xml,放在类路径的根目录下
-
3.在Dao.xml的mapper标签中配置使用自定义的缓存
-
4.如果要和别的dao共用一个缓存,只需要在当前dao.xml的mapper标签里面引用别的dao的缓存即可
=====================================================================================
环境搭建:
Lock类:
public class main {
static SqlSessionFactory sqlSessionFactory;
static public void initSqlSessionFactory() throws IOException {
String resource = “MyBaits-config.xml”;
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
}
public static void main(String[] args) throws IOException
{
initSqlSessionFactory();
SqlSession sqlSession = sqlSessionFactory.openSession(true);
try{
LockDao lock = sqlSession.getMapper(LockDao.class);
Lock l1=new Lock();
l1.setId(1);
l1.setName(“%锁”);
l1.setPrice(1000);
Lock l = lock.getLockByCondition(l1);
System.out.println(l);
}finally
{
sqlSession.close();
}
}
}
LockDao接口类:
public interface LockDao {
public Lock getLockByCondition(Lock lock);
}
LockDao.xml:
<?xml version="1.0" encoding="UTF-8" ?>SELECT l.id,l.lockName name,l.price FROM lock
l where
id > #{id} and
lockName like #{name} and
price < #{price}
MyBaits-config.xml:
main:
public class main {
static SqlSessionFactory sqlSessionFactory;
static public void initSqlSessionFactory() throws IOException {
String resource = “MyBaits-config.xml”;
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
}
public static void main(String[] args) throws IOException
{
initSqlSessionFactory();
SqlSession sqlSession = sqlSessionFactory.openSession(true);
try{
LockDao lock = sqlSession.getMapper(LockDao.class);
Lock l1=new Lock();
l1.setId(1);
l1.setName(“%锁”);
l1.setPrice(1000);
Lock l = lock.getLockByCondition(l1);
System.out.println(l);
}finally
{
sqlSession.close();
}
}
}
结果:
where 元素只会在子元素返回任何内容的情况下才插入 “WHERE” 子句。而且,若子句的开头为 “AND” 或 “OR”,where 元素也会将它们去除。
写了where标签后,后自动在sql语句后面拼接一个where
我们查询的条件就放在where标签中,每个and写在前面,where自动帮我们取出多余的and
<?xml version="1.0" encoding="UTF-8" ?>SELECT l.id,l.lockName name
,l.price FROM lock
l
id > #{id} and
lockName like #{name} and
price < #{price}
截取字符串
prefix=“” :前缀,为我们下面的sql语句整体添加一个前缀
prefixOverrides=“” :取出整体字符串前面可能多余的字符
suffix=“” :为整体添加一个后缀
suffixOverrides=“”:取出整体字符串后面可能多用的字符
下面自动帮我们添加一个where前缀,去掉整体最开始的and和最后的and
<?xml version="1.0" encoding="UTF-8" ?>SELECT l.id,l.lockName name
,l.price FROM lock
l
and id > #{id}
and lockName like #{name}
and price < #{price} and
LockDao接口类:
public interface LockDao {
public List getLockByCondition(@Param(“list”) List listId);
}
LockDao.xml:
<?xml version="1.0" encoding="UTF-8" ?>SELECT l.id,l.lockName name
,l.price FROM lock
l WHERE id IN
/对应list集合来说,key默认为list,我们也可以自己指定参数的key值/
#{id_item}
main:
public class main {
static SqlSessionFactory sqlSessionFactory;
static public void initSqlSessionFactory() throws IOException {
String resource = “MyBaits-config.xml”;
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
}
public static void main(String[] args) throws IOException
{
initSqlSessionFactory();
SqlSession sqlSession = sqlSessionFactory.openSession(true);
try{
LockDao lock = sqlSession.getMapper(LockDao.class);
List idList=new LinkedList();
idList.add(1);
idList.add(2);
idList.add(3);
idList.add(4);
idList.add(5);
List lockList = lock.getLockByCondition(idList);
for(Lock l:lockList)
{
System.out.println(1);
}
}finally
{
sqlSession.close();
}
}
}
LockDao.xml :
<?xml version="1.0" encoding="UTF-8" ?>SELECT l.id,l.lockName name
,l.price FROM lock
l
id=#{id}
id=2
LockDao接口:
public interface LockDao {
public Lock getLockByCondition(@Param(“id”) Integer id);
}
如果传入对象,那么在使用属性名的时候可以识别
传入基本数据类型时,防止如下错误发生:There is no getter for property named id in class java.lang.Integer ,给参数设置key名
字段部分更新-----》if结合set
update lock
lockName=#{name},
price=#{price},
id=#{id}
![在这里插入
图片描述](https://img-blog.csdnimg.cn/adf8b6a9bce6471298a24709fe38f629.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L20wXzUzMTU3MTcz,size_16,color_FFFFFF,t_70)
不仅可以直接调用属性,还可以调用方法
OGNL表达式里面的集合伪属性
//前提,list是集合
不仅可以判断参数,还可以判断_parameter和_databasedId
bind 元素允许你在 OGNL 表达式以外创建一个变量,并将其绑定到当前的上下文。比如:
SELECT * FROM BLOG
WHERE title LIKE #{pattern}
要在带注解的映射器接口类中使用动态 SQL,可以使用 script 元素
=================================================================
一级缓存失效情况
手动清空缓冲的函数:
sqlSession.clearCache();
二级缓存: namespace级别的缓存,隔一段时间会自动刷新缓存