sql 模糊查询语句

用到sql模糊查询时,发现之前数据库课上学到的东西又还给老师了,就重温一下。。。

先举两个例子,最后有like表达式的具体介绍:

1、查询所有以“数据”开头的课程名

select Cname

from course

where Cname like '数据%';

2、查询姓李并且姓名只有两个汉字的学生的学号和姓名 

select Sno,Sname

from student

where Sname like '李--';

3、查询以C-打头的课程的详细信息

select *

from course

where Cname like 'C\-%' escape '\'

根据名称模糊查询,用到like表达式,like表达式的一般形式为:

<匹配值>【not】like <模式>【escape <‘转义字符’>】

<匹配值>是数据库中的属性,<模式>是字符串常量,它们两个能进行比较;<模式>中允许使用通配符。

      有两种通配符:

      1、‘-’ (下横线)可以与单个字符匹配。

      2、‘%’(百分号)可以与零个或多个字符匹配

escape<’换码字符‘> 例如:escape '\',它定义“\”为转义字符,将紧随其后的一个字符进行转义。

如果“-”或者“%”紧跟在“\”后面,就失去了通配符的意义,只取其字面意义。

### SQL 模糊查询语句使用 LIKE 关键字 示例教程 在 SQL 中,`LIKE` 是一种用于执行模式匹配的关键字。它通常与 `%` `_` 这两个通配符一起使用来实现模糊查询功能。 #### 基本语法 ```sql SELECT column_name(s) FROM table_name WHERE column_name LIKE pattern; ``` - `column_name`: 被查询的列名称。 - `table_name`: 数据表的名称。 - `pattern`: 匹配模式,可以包含通配符 `%` 或 `_`。 --- #### 通配符说明 1. **百分号 (`%`)** - 表示零个或多个任意字符。 - 例如:`'%张%'` 将匹配任何包含“张”的字符串[^2]。 2. **下划线 (`_`)** - 表示单个任意字符。 - 例如:`'_心%'` 将匹配第二个字符为“心”的所有字符串[^3]。 --- #### 示例代码 以下是几个常见的 SQL 模糊查询示例: ##### 示例 1: 查找名字中包含特定子串的数据 假设有一个名为 `student` 的表格,其中有一列 `sname` 存储学生的名字。如果想查找名字中包含“张”的学生信息: ```sql SELECT * FROM student WHERE sname LIKE '%张%'; ``` 这将返回所有名字中包含“张”的记录。 --- ##### 示例 2: 查找以某个字符开头的数据 如果需要找到名字以“李”开头的学生信息: ```sql SELECT * FROM student WHERE sname LIKE '李%'; ``` 此查询会返回所有以“李”开头的名字[^2]。 --- ##### 示例 3: 查找以某个字符结尾的数据 如果希望查找出名字以“明”结尾的学生信息: ```sql SELECT * FROM student WHERE sname LIKE '%明'; ``` 该查询仅返回那些以“明”作为最后一个字符的名字。 --- ##### 示例 4: 查找指定位置上的字符 假如想要获取名字中的第二个字符为“晓”的学生信息: ```sql SELECT * FROM student WHERE sname LIKE '_晓%'; ``` 这里的下划线表示第一个字符可以是任意值,“晓”固定位于第二位[^3]。 --- ##### 示例 5: 处理特殊字符 (如 `_`) 当查询条件涉及特殊字符(如 `_`)时,可以通过反斜杠 `\` 来转义这些字符。例如,查找名字中含有实际字符“_”的情况: ```sql SELECT name FROM student WHERE name LIKE '%\_%'; ``` 这条语句能够正确识别并提取含有下划线的实际内容[^3]。 --- ### 总结 通过以上实例可以看出,在 SQL 查询过程中灵活运用 `LIKE` 及其配套的通配符可以帮助我们轻松完成各种复杂的模糊匹配需求。无论是简单的部分匹配还是更精确的位置限定都可以借助这一机制得以解决。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值