当前位置: 首页 > news >正文

网站建设公司怎么做业务南宁seo计费管理

网站建设公司怎么做业务,南宁seo计费管理,建站之星网站建设下载版,网站开发成本估计简单介绍: 在我们之前使用where关键字进行查询的时候,总是会在后面添加一个11恒等式,并且在每一个可能拼接的SQL语句前面都加上一个and关键字,防止当后续的所有条件都不满足的时候,where关键字在最后直接跟and的时候也…

简单介绍:

在我们之前使用where关键字进行查询的时候,总是会在后面添加一个1=1恒等式,并且在每一个可能拼接的SQL语句前面都加上一个and关键字,防止当后续的所有条件都不满足的时候,where关键字在最后直接跟and的时候也能不报错。在本章节的学习中,我么将要学习一个新的标签<where>可以帮助我们在我们拼接SQL语句的时候i,灵活的添加或者不添加where关键字。

使用方法:

<select id="唯一标识" resultType="结果集映射的实体类">

        select * from student

        <where>

                <if test="判断条件">

                        and 需要拼接的SQL语句

                </if>

                <if test="判断条件">

                        and 需要拼接的SQL语句

                </if>

        </where>

</select>

代码实现:

SQL映射文件:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="Mappers.dynamicSql"><select id="selectByIdOrName" parameterType="student" resultType="student">select * from student where 1=1
#                             当id的值不等于null并且id的值不是空字符的时候,就会拼接这个SQL语句<if test="id != null and id != ''">and id = #{id}</if>
#                             当name的值不等于null的时候并且name的值不是空字符串的时候,就会拼接这个SQL语句<if test="name != null and name != ''">
#                             注意这个地方是使用了一个concat函数将模糊匹配的百分号和参数进行拼接,在使用的时候注意这个地方不要写错and name like concat ('%',#{name},'%')</if></select><select id="selectAll" resultType="student">select * from student;</select>
<!--    动态SQL中的choose元素-->
<!--    当查询的条件满足第一个when的时候,就拼接第一个when里面的SQL语句-->
<!--    当查询的条件满足第二个when的时候,就拼接第二个when里面的SQL语句-->
<!--    当所有的when都不满足的时候,就拼接otherwise里面的SQL语句-->
<!--    当有多个when里面的条件都满足的时候,就拼接最靠上的一条SQL语句,并且不会执行其他when里面的语句--><select id="selectStudentByIdAndName" resultType="student" >select * from student where 1=1<choose><when test="name != null and name != ''">and name like concat('%',#{name},'%')</when><when test="id != null and id != ''">and id = #{id}</when><otherwise>and password is not null</otherwise></choose></select>
<!--    使用<where>来动态的处理where关键字是否添加--><select id="selectByIdAndWhere" resultType="student">select * from student<where><if test="name != null and name !=''">and name like concat('%',#{name},'%')</if><if test="id != null and id !=''">and id = #{id}</if></where></select>
</mapper>

接口文件:

package Mappers;import com.mybatis.POJO.student;import java.util.List;public interface dynamicSql {List<student> selectByIdOrName(student s);List<student> selectStudentByIdAndName(student s);List<student> selectByIdAndWhere(student s);
}

测试类:

package Mappers;import com.mybatis.POJO.Tools.createSqlSession;
import com.mybatis.POJO.student;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;import java.util.List;public class dynamicSqlTest {@Testpublic void selectByIdOrName(){SqlSession sqlSession = new createSqlSession().create();dynamicSql dynamicSql = new createSqlSession().createdynamicSql();student s = new student();s.setId(1);s.setName("张三");List<student> stu = sqlSession.selectList("Mappers.dynamicSql.selectByIdOrName", s);for(student student : stu){System.out.println(student.toString());}}@Testpublic void selectStudentByIdAndName(){dynamicSql dynamicSql = new createSqlSession().createdynamicSql();student s =new student();
//        s.setId(1);
//        s.setName("张三");for (student student : dynamicSql.selectStudentByIdAndName(s)) {System.out.println(student);}}@Testpublic void selectAll(){SqlSession sqlSession = new createSqlSession().create();dynamicSql dynamicSql = new createSqlSession().createdynamicSql();List<student> list = sqlSession.selectList("Mappers.dynamicSql.selectAll");for(student student : list){System.out.println(student.toString());}}@Testpublic void selectByIdAndWhere(){SqlSession sqlSession = new createSqlSession().create();dynamicSql dynamicSql = new createSqlSession().createdynamicSql();student s = new student();
//        s.setId(1);s.setName("张三");for (student student : dynamicSql.selectByIdAndWhere(s)) {System.out.println(student.toString());}}
}

运行结果:

当我们使用where标签的时候,即使SQL语句中没有where关键字,MyBatis也会自动的帮助我们进行添加,同样的,如果我们的where关键字后面没有任何的查询语句,MyBatis会帮我们删除多余的where关键字。

当我们正常进行查询的时候:

可以看到我们的查询语句后面是没有where关键字的,接着我们来运行程序:

 

可以看到是可以正常的查询的,说明MyBatis在我们的查询语句后面插入了一个where关键字帮我们构建出了一个完整的SQL语句

如果我们if条件都达不到的时候,也就是说where后面没有任何需要拼接的时候,where还会不会自动添加?:

运行结果:

 

结果依然正常的显示了,说明where关键字并没有添加,这就证明了<where>标签可以动态的自动识别是否应该添加where关键字。 

注意点:

在这个案例中,需要注意的就是<where>标签的位置和<select>的嵌套关系,以及在注意在拼接SQL关键字的时候需要遗漏and关键字。如果出现了运行报错的情况,优先考虑是否是<where>的位置和SQL拼接的问题。

如果出现了查询结果不符合猜想的情况优先考虑是否是因为在SQL拼接的时候遗漏了某些关键字或者是条件判断的错误

http://www.mmbaike.com/news/96696.html

相关文章:

  • 做网站需要做什么搜索引擎营销优化的方法
  • 网站备案注销 万网搜索引擎排名
  • 中山网站优化最有效的免费推广方法
  • 产品销售网站模块如何设计国际新闻头条今日国际大事
  • uehtml 网站源码外贸平台有哪些
  • 湛江模板建站哪家好中国免费网站服务器主机域名
  • 如何给网站增加内链百度指数的网址是什么
  • 河南高端网站建设cba最新排名
  • 好的ftp网站给企业做网站的公司
  • 网站网页制作公司网站刷关键词排名软件
  • 网站建设品牌策划方案广东企业网站seo报价
  • 网站建设公司无锡seo快速排名代理
  • 四川长昕建设工程有限公司网站宁波专业seo服务
  • 一流的龙岗网站建设精准营销平台
  • 南沙滩做网站公司网站宣传推广策划
  • 蓝色系列的网站近三天的国内外大事
  • 福田附近公司做网站建设哪家效益快如何在百度上做推广
  • 新浪 博客可以做网站优化吗360收录
  • 可视化web网站开发自媒体怎么做
  • 三亚网站定制网络优化有前途吗
  • 专业做公墓 陵园的网站上海网站建设优化
  • wordpress.模板seo优化效果怎么样
  • 宁海哪家做网站比较可靠而的跟地seo排名点击软件
  • 网站icp是什么意思如何制作网页最简单的方法
  • 网站开发要注意安全性优化关键词怎么做
  • 帮你做海报网站网页模板代码
  • 常州建设局官方网站在线生成网站
  • 月付商城网站建站网站宣传的方法有哪些
  • 深圳网站建设开发公司win7优化大师官方网站
  • 香港外贸网站建设seo推广是什么