SQL字符匹配实践:LIKE操作与通配符应用

0 下载量 4 浏览量 更新于2024-08-28 1 收藏 92KB PDF 举报
本篇文档是针对2019-2020春学期的数据库作业,专注于SQL练习中的单表查询,特别是关于SELECT语句的字符匹配功能。SQL的LIKE谓词在此部分被详细介绍,用于执行字符串匹配操作。它支持两种通配符: 1. `%` (百分号):代表任意长度的字符串,包括零长度。例如,`Sname LIKE '刘%'` 会匹配所有姓刘的学生名字。 2. `_` (下划线):代表单个任意字符。例如,`Sname LIKE '欧阳__'` 用于查找全名有三个汉字且姓氏为“欧阳”的学生。 作业示例包括查询学号、姓名和性别: - 查询学号为201215121的学生信息:`SELECT * FROM Student WHERE Sno LIKE '201215121';` - 查询所有姓刘的学生信息:`SELECT Sname, Sno, Ssex FROM Student WHERE Sname LIKE '刘%';` - 查询名字中第二个字符为“阳”的学生信息:`SELECT Sname, Sno FROM Student WHERE Sname LIKE '_阳%';` 值得注意的是,LIKE操作符等价于等于号(`=`),而不含通配符的字符串可以直接使用等号。对于含有通配符的情况,如果通配符本身出现在查询字符串中,需要使用ESCAPE关键字进行转义,例如查询特定课程的课程号和学分:`SELECT Cno, Ccredit FROM Course WHERE Cname LIKE 'DB_Design' ESCAPE '\';` 这里的`\` 表示对下划线`_`进行转义,使其不再是通配符。 总结来说,本练习着重训练学生理解和运用SQL的LIKE和NOT LIKE操作符以及通配符的使用,以实现灵活的字符串匹配查询。这对于数据库管理和数据分析至关重要,能够帮助学生掌握如何在实际场景中高效筛选和检索数据。