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

临桂建设局网站如何进行电子商务网站推广?

临桂建设局网站,如何进行电子商务网站推广?,昆明做网站公司,十大免费跨境电商平台动态 SQL 是 MyBatis 的强大特性之一。在 JDBC 或其它类似的框架中,开发人员通常需要手动拼接 SQL 语句。根据不同的条件拼接 SQL 语句是一件极其痛苦的工作。例如,拼接时要确保添加了必要的空格,还要注意去掉列表最后一个列名的逗号。而动态…

动态 SQL 是 MyBatis 的强大特性之一。在 JDBC 或其它类似的框架中,开发人员通常需要手动拼接 SQL 语句。根据不同的条件拼接 SQL 语句是一件极其痛苦的工作。例如,拼接时要确保添加了必要的空格,还要注意去掉列表最后一个列名的逗号。而动态 SQL 恰好解决了这一问题,可以根据场景动态的构建查询

动态 SQL 只有几个基本元素,与 JSTL 或 XML 文本处理器相似,十分简单明了,大量的判断都可以在 MyBatis 的映射 XML 文件里配置,以达到许多需要大量代码才能实现的功能。动态 SQL 大大减少了编写代码的工作量,更体现了 MyBatis 的灵活性、高度可配置性和可维护性

if标签:条件判断

MyBatis if 类似于 Java 中的 if 语句,是 MyBatis 中最常用的判断语句

if 语句使用方法简单,常常与 test 属性联合使用。语法如下

<if test="判断条件">SQL语句
</if>

当判断条件为 true 时,才会执行所包含的 SQL 语句。
最常见的场景是在 if 语句中包含 where 子句,例如

<select id="selectAllWebsite" resultMap="myResult">select id,name,url from website<if test="name != null">where name like #{name}</if>
</select>

以上代表表示根据网站名称去查找相应的网站信息,但是网站名称是一个可填可不填的条件,不填写的时候不作为查询条件。


可多个 if 语句同时使用。以下语句表示为可以按照网站名称(name)或者网址(url)进行模糊查询。如果您不输入名称或网址,则返回所有的网站记录。但是,如果你传递了任意一个参数,它就会返回与给定参数相匹配的记录。

<select id="selectAllWebsite" resultMap="myResult">select id,name,url from website where 1=1<if test="name != null">AND name like #{name}</if><if test="url!= null">AND url like #{url}</if>
</select>

choose、when和otherwise标签

MyBatis 中动态语句 choose-when-otherwise 类似于 Java 中的 switch-case-default 语句。由于 MyBatis 并没有为 if 提供对应的 else 标签,如果想要达到<if>...<else>...</else> </if> 的效果,可以借助 <choose>、<when>、<otherwise> 来实现。
动态语句 choose-when-otherwise 语法如下

<choose><when test="判断条件1">SQL语句1</when ><when test="判断条件2">SQL语句2</when ><when test="判断条件3">SQL语句3</when ><otherwise>SQL语句4</otherwise>
</choose>

choose 标签按顺序判断其内部 when 标签中的判断条件是否成立,如果有一个成立,则执行相应的 SQL 语句,choose 执行结束;如果都不成立,则执行 otherwise 中的 SQL 语句。这类似于 Java 的 switch 语句,choose 为 switch,when 为 case,otherwise 则为 default。

示例

以下示例要求:

  • 当网站名称不为空时,只用网站名称作为条件进行模糊查询;
  • 当网站名称为空,而网址不为空时,则用网址作为条件进行模糊查询;
  • 当网站名称和网址都为空时,则要求网站年龄不为空。

 WebsiteMapper.xml 代码如下

<mapper namespace="net.cc.mapper.WebsiteMapper"><select id="selectWebsite"parameterType="net.cc.po.Website"resultType="net.cc.po.Website">SELECT id,name,url,age,countryFROM website WHERE 1=1<choose><when test="name != null and name !=''">AND name LIKE CONCAT('%',#{name},'%')</when><when test="url != null and url !=''">AND url LIKE CONCAT('%',#{url},'%')</when><otherwise>AND age is not null</otherwise></choose></select>
</mapper>

测试类代码

public class Test {public static void main(String[] args) throws IOException {// 读取配置文件mybatis-config.xmlInputStream config = Resources.getResourceAsStream("mybatis-config.xml"); // 根据配置文件构建SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(config);// 通过SqlSessionFactory创建SqlSessionSqlSession ss = ssf.openSession();Website site = new Website();site.setname("编程");List<Website> siteList = ss.selectList("net.cc.mapper.WebsiteMapper.selectWebsite", site);for (Website ws : siteList) {System.out.println(ws);}}
}

http://www.yayakq.cn/news/140609/

相关文章:

  • 江苏高校品牌专业建设工程网站网络广告文案范文
  • 用别人的照片做网站重庆关键词快速排名
  • 黄山网站优化短链生成网站
  • 建设网站内容的策划书苏州微信小程序开发公司
  • 舟山市建设局网站php免费网站源码
  • 广州做网站平台太仓有专门做网站的地方吗
  • 0311网站建设kn95口罩
  • 网站开发常用的数据库网站收录是什么
  • 做网站530元网站sem
  • 做网站在哪里做网站的公司那家好
  • 怎么知道网站谁建的百度联盟app
  • 二维码短链接生成器贵州便宜网站推广优化电话
  • 南海佛山网站建设网页设计公司的目标客户有哪些
  • 上海网站建设 网页制作seo人员的职责
  • 天津网站建设公司最好文字网站居中
  • 咸鱼网站交易付款怎么做企业管理工具
  • 无锡装修网站阿里云wordpress一键安装包
  • 建设推广型网站建设银行人力资源系统网站怎么进
  • 上海网站制作建设多少钱网站开发程序员是什么学校毕业
  • 如何制作百度网站地图网上智慧团建官网
  • 花生壳域名可以做网站域名吗网站怎么做外链
  • 如何用ps做创意视频网站广州市城市建设
  • sogo提交网站入口淘宝放单网站怎么做
  • 橙色主题手机网站网站类型定位分析
  • 河南省建设工程质量监督信息网企业网站分析与优化
  • 安徽省博物馆网站建设wordpress站群管理破解版
  • 网站备案 更改ipnginx wordpress 优化
  • 个人信息管理网站建设wordpress 自定义网址链接
  • 政务网站建设的三大核心功能是什么seo诊断网站免费诊断平台
  • 百度站长平台链接提交协达网站建设