如何解决SQL-如何在WHERE子句中避免使用多个OR运算符?
sqlite> .schema movie
CREATE TABLE movie (
id INTEGER PRIMARY KEY,title TEXT,year INTEGER,nth TEXT,for_video BOOLEAN
);
sqlite>
sqlite>
sqlite>
问题:
哪个电影不算标题以标点符号开头,字母顺序排在前,后排在后的电影?
以下语法:
SELECT title
FROM movie
WHERE NOT(title LIKE '%!%' or title LIKE '%#%' or title LIKE '%$%')
ORDER BY title ASC LIMIT 1;
永远不会结束或运算符。
语法应在mysql和sqlite中工作
如何避免使用多个OR
运算符检查标点符号?尚未添加更多OR
运算符进行标点检查...
解决方法
对于第一部分(多个OR)。另请注意,联接(Like
)的语法不同
您可以创建一个标点符号表并将数据添加到其中
Create table Punctuations (punckSign varchar(10))
insert into Punctuations
values ('!'),('#'),('$')
然后按如下所示将其与电影表连接起来
MySQL
SELECT title FROM movie m
Left join Punctuations p
on title like concat('%',p.punckSign,'%')
where p.punckSign is null
SQLite
SELECT title FROM movie m
Left join Punctuations p
on title like '%'|| p.punckSign || '%'
where p.punckSign is null
,
使用REGEXP尝试以下操作
SELECT title
FROM movie
WHERE title not REGEXP '!|#|$'
ORDER BY title ASC LIMIT 1;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。