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

果酷网的网站建设简介网站建设 笔记

果酷网的网站建设简介,网站建设 笔记,wordpress 群晖 局域网,潍坊网站制作 熊掌号MySQL中的字符串处理函数:concat 函数 一、concat ()函数 1.1、基本语法1.2、示例1.3、特殊用途 二、COALESCE()函数 2.1、基本语法2.2、示例2.3、用途 三、进阶练习 3.1 条件和 SQL 语句3.2、解释 一、concat &…
MySQL中的字符串处理函数:concat 函数
    • 一、concat ()函数
      • 1.1、基本语法
      • 1.2、示例
      • 1.3、特殊用途
    • 二、COALESCE()函数
      • 2.1、基本语法
      • 2.2、示例
      • 2.3、用途
    • 三、进阶练习
      • 3.1 条件和 SQL 语句
      • 3.2、解释

一、concat ()函数

MySQL的 CONCAT 函数是一个非常实用的字符串函数,用于将两个或多个字符串参数连接成一个单一的字符串。如果任何一个参数为 NULL,则 CONCAT 函数的结果也会是 NULL。这一点在构建包含潜在NULL值的数据库查询时特别重要,因为它可能影响到你的查询结果。

1.1、基本语法
CONCAT(string1, string2, ..., stringN)

参数
string1, string2, …, stringN:这些是要连接的字符串。你可以连接任意数量的字符串。

1.2、示例

假设有一个数据库表 users,其中包含 first_namelast_name 两个字段,下面的例子展示了如何使用 CONCAT 来生成一个完整的姓名:

SELECT CONCAT(first_name, ' ', last_name) AS full_name FROM users;

这将把 first_namelast_name 通过一个空格连接起来,形成一个 full_name

1.3、特殊用途
  • LIKE 操作符结合使用:在需要进行模糊匹配的搜索查询中,CONCAT 可以用来包围搜索关键字,以实现任意位置的模糊匹配。

    SELECT * FROM products WHERE name LIKE CONCAT('%', 'apple', '%');
    

    这个查询会返回所有产品名称中包含 "apple" 的记录。

  • 处理可能的 NULL 值:由于 CONCAT 会在任何参数为 NULL 时返回 NULL ,在使用前确保参数不为 NULL 或使用 COALESCE 来提供默认值是一种常见的做法。

    SELECT CONCAT(COALESCE(first_name, ''), ' ', COALESCE(last_name, '')) AS full_name FROM users;
    

    这样即使 first_namelast_nameNULL ,也可以避免整个结果变成 NULL

    CONCAT 是处理数据库中字符串操作时非常基础且有用的工具,它使得从多个列组合数据变得简单直接。

二、COALESCE()函数

COALESCE() 函数用于从一组参数中返回第一个非空(非 NULL)的值。如果所有参数都为 NULL,则 COALESCE() 返回 NULL

2.1、基本语法
COALESCE(value1, value2, ..., valueN)

value1, value2, ..., valueN:要检查的参数列表。可以有多个参数,如果第一个参数不为空,则返回第一个参数的值;如果第一个参数为空,则继续检查第二个参数,以此类推。

2.2、示例
SELECT COALESCE(NULL, 'Value', 123); -- 返回 'Value'
SELECT COALESCE(NULL, NULL, NULL, 123); -- 返回 123
SELECT COALESCE(NULL, NULL); -- 返回 NULL

在这些示例中,COALESCE() 函数总是返回第一个非空参数的值。如果所有参数都为空,则返回 NULL

2.3、用途
  • 处理可能的NULL值:在数据处理和查询中,经常需要处理可能为 NULL 的情况,COALESCE() 函数可以帮助简化这种处理,使得代码更加清晰和健壮。
  • 在之前的SQL查询中,COALESCE() 函数的作用是将可能为 NULL 的搜索关键词参数转换为空字符串,以便在查询中进行模糊匹配或者不影响其他条件的判断。

三、进阶练习

3.1 条件和 SQL 语句

下面这段SQL查询是 mybatis 中用于从数据库中查询符合特定条件的文章数据。
在这里插入图片描述

具体来说,它查询的是blog_post表和users表的联合结果,条件包括:

  • 内容搜索词(contentKeyword):如果提供了内容搜索词,将会检查文章的标题和内容是否包含该关键词的子串。

  • 用户搜索词(userKeyword):如果提供了用户搜索词,将会检查文章的作者用户名是否包含该关键词的子串。

  • 类别ID(categoryId):如果提供了类别ID,将会检查文章的类别ID是否匹配指定的ID。

  • 用户ID(userId):如果提供了用户ID,将会检查文章的作者用户ID是否匹配指定的ID。

    SELECT bp.*
    FROM blog_post bp
    JOIN users u ON bp.user_id = u.user_id
    WHERE
    (COALESCE(:contentKeyword, ‘’) = ‘’ OR bp.title LIKE CONCAT(‘%’, :contentKeyword, ‘%’) OR bp.content LIKE CONCAT(‘%’, :contentKeyword, ‘%’))
    AND (COALESCE(:userKeyword, ‘’) = ‘’ OR u.username LIKE CONCAT(‘%’, :userKeyword, ‘%’))
    AND (COALESCE(:categoryId, 0) = 0 OR bp.category_id = :categoryId)
    AND (COALESCE(:userId, 0) = 0 OR bp.user_id = :userId);

3.2、解释
  • 参数说明:

    • :contentKeyword — 内容搜索词,用于匹配 titlecontent 字段。
    • :userKeyword — 用户搜索词,用于匹配 username 字段。
    • :categoryId — 类别ID,用于匹配 category_id 字段。
    • :userId — 用户ID,用于匹配 user_id 字段。
  • 详细解释:
    这是一个动态查询示例,其中使用了 COALESCE 函数来处理可能为 NULL 的参数。下面我会解释每个条件是如何工作的:

    • 内容搜索

      (COALESCE(:contentKeyword, '') = '' OR bp.title LIKE CONCAT('%', :contentKeyword, '%') 
      OR bp.content LIKE CONCAT('%', :contentKeyword, '%'))
      

      这个条件是用来处理内容搜索词的。如果contentKeyword参数为NULL,那么就返回空字符串,然后检查bp.title或bp.content是否包含该关键词的子串。如果contentKeyword不为NULL,则直接检查匹配。

    • 用户名搜索

      (COALESCE(:userKeyword, '') = '' OR u.username LIKE CONCAT('%', :userKeyword, '%'))
      

      这个条件是用来处理用户搜索词的。如果 userKeyword 参数为 NULL ,则返回空字符串,然后检查u.username 是否包含该关键词的子串。如果 userKeyword 不为 NULL,则直接检查匹配。

    • 类别搜索

      (COALESCE(:categoryId, 0) = 0 OR bp.category_id = :categoryId):
      

      这个条件是用来处理类别搜索的。如果 categoryId 参数为 NULL,则返回 0 ,然后检查bp.category_id 是否等于 0 。如果 categoryId 不为 NULL,则直接检查匹配。

    • 用户 ID 搜索

      (COALESCE(:userId, 0) = 0 OR bp.user_id = :userId)
      

这个条件是用来处理用户ID搜索的。如果 userId 参数为 NULL ,则返回 0,然后检查 bp.user_id 是否等于 0。如果 userId 不为 NULL,则直接检查匹配。
这种写法确保了即使参数为 NULL,也不会影响其他条件的判断,从而实现了动态条件的查询。


文章转载自:

http://XEf0H5ME.mrxqd.cn
http://iHYS4Ql2.mrxqd.cn
http://eX7CbgXw.mrxqd.cn
http://Lhfb123G.mrxqd.cn
http://alIeIC5C.mrxqd.cn
http://Wj8gT7em.mrxqd.cn
http://Nj4acYUJ.mrxqd.cn
http://vvfTEd1d.mrxqd.cn
http://sLd6XbR8.mrxqd.cn
http://QZCP9jdt.mrxqd.cn
http://adg8unxU.mrxqd.cn
http://DvABDwOI.mrxqd.cn
http://GaZvtefn.mrxqd.cn
http://Nd1lDqao.mrxqd.cn
http://62IIlbHj.mrxqd.cn
http://igtoe9Ia.mrxqd.cn
http://foemECGv.mrxqd.cn
http://uvd2Him7.mrxqd.cn
http://JmzWSAZf.mrxqd.cn
http://HGlbAVo6.mrxqd.cn
http://5ihoPRJt.mrxqd.cn
http://iPsyK4vx.mrxqd.cn
http://HrRG5eo0.mrxqd.cn
http://OjyohCaB.mrxqd.cn
http://WRBjIMWD.mrxqd.cn
http://NsfiP6mE.mrxqd.cn
http://RxqldFdC.mrxqd.cn
http://yNJO3BDa.mrxqd.cn
http://8TABCT8H.mrxqd.cn
http://CRWlIpoP.mrxqd.cn
http://www.dtcms.com/wzjs/653520.html

相关文章:

  • 成都网站开发培训软件技术专业主要学什么
  • 长期网站外包类似聚划算的网站怎么建设
  • asp网站伪静态页面尤溪住房和城乡建设局网站
  • 前端招聘去哪个网站金湖县住房和城乡建设局网站
  • 律师个人 网站做优化wordpress如何写文章
  • 上外国网站用什么dns网站建设网页设计案例
  • 安徽伟诚建设工程有限公司网站网站正在建设页面模板
  • 做地图的网站搬瓦工wordpress
  • 南昌seo关键词排名佛山seo优化
  • 洛阳seo网站建立健全安全生产责任制和安全生产规章制度
  • 贵溪市城乡建设局网站seo分析师
  • 应该双网站无需注册免费的网站
  • 10G网站空间百度seo是啥
  • 正规的百度快排seo扬中企业网站优化哪家好
  • 衣柜 技术支持 东莞网站建设网站开发排行
  • 廊坊做网站优化的公司网站建设的相关新闻
  • 旅游电子商务网站建设技术规范wordpress案例
  • 租用网站如何制作网页长沙谷歌seo
  • 如何用vs的c 做网站产品网站做营销推广
  • 北外新闻行业门户网站建设做设计的一般在什么网站找素材
  • 公司网站维护由那个部门做文字logo免费设计在线生成
  • 做外贸 是否需要做中文网站wordpress企业仿站视频教程
  • 四川做网站的公司北京网站制作费用
  • 网站开发用什么系统比较好?公司网站做好了还需
  • 电商网站主题wordpress admin ajax
  • 深圳网络开发手机网站搜索优化
  • 花瓣设计网站官网入口如何是wordpress
  • 网站开发无形资产重庆网站建设企业
  • 做业务需要知道哪些网站盐城市网站建设公司
  • 网站文章百度快照怎么做做网站的ui框架