热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在SQLSever中更好地使用LIKE?

例如,我有下表。我的目标是选择国家“萨克森”的项目。但是对于上面的WHERE子句,它不起作用。我得到了所有

例如,我有下表。

我的目标是选择国家“萨克森”的项目。但是对于上面的 WHERE 子句,它不起作用。我得到了所有 3 个项目。

他们是一个简单的解决方案吗?

回答

问题在于您的设计,而不是您的查询。修复您的设计,修复查询。

而不是在您的列中存储分隔数据,状态,似乎您应该为您的状态创建一个单独的表。我假设你的表有其他列,所以这是Pseudo SQL,但应该指向正确的方向:

CREATE TABLE dbo.Project (ProjectID int NOT NULL PRIMARY KEY,
{Other columns, not State});
CREATE TABLE dbo.State (StateID int NULL NULL PRIMARY KEY,
StateName nvarchar(50));
CREATE TABLE dbo.ProjectState (ProjectID int,
StateID int);
ALTER TABLE dbo.ProjectState ADD CONSTRAINT FK_ProjectState_Project FOREIGN KEY (ProjectID) REFERENCES dbo.Project (ProjectID);
ALTER TABLE dbo.ProjectState ADD CONSTRAINT FK_ProjectState_State FOREIGN KEY (StateID) REFERENCES dbo.State (StateID);
GO

然后你会插入这样的数据:

INSERT INTO dbo.State (StateID,StateName)
VALUES (1,'Berlin'),(2,'Sachsen');
INSERT INTO dbo.Project (ProjectID, {OtherColumns})
VALUES (1, {OtherColumns});
INSERT INTO dbo.StateProject (ProjectID, StateID)
VALUES(1,1),(1,2);

然后你只需使用几个JOINs 和一个=运算符:

SELECT {Required Columns}
FROM dbo.Project P
JOIN dbo.ProjectState PS ON P.ProjectID = PS.ProjectID
JOIN dbo.State S ON PS.StateID = S.StateID
WHERE S.StateName = 'Sachsen';






推荐阅读
author-avatar
不如藏拙_487
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有