首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >内联SQL是硬编码吗?

内联SQL是硬编码吗?
EN

Stack Overflow用户
提问于 2011-03-15 03:58:38
回答 8查看 6.7K关注 0票数 5

我听一些有实力的开发人员说“内联SQL本身并不是坏事”。我不明白内联SQL是如何被接受的。对我来说,这就像是硬编码。许多开发人员会嘲笑我将连接字符串放在代码中而不是放在配置文件中。那么,为什么"SELECT value1,value2 FROM TABLE“在编译代码中是完全可以接受的呢?

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2011-03-15 04:07:44

我认为在数据库查询和围绕它的代码之间存在大量的耦合。例如,查询可能从数据库中获取特定用户的名字和姓氏,然后创建一个包含名字和姓氏的XML文件。

如果你把数据库查询放在其他地方(例如配置文件),你可能看起来增加了可配置性和灵活性。但是,如果您想实际更改它,比如向XML文件添加一个名为"age“的字段,则不能只更改查询,还需要更改编写XML文件的代码。因此,实际上,您已经将必须更改一段代码的问题替换为必须更改两件事情(代码和配置)的问题,以及它们可能不一致的危险,并且您没有获得任何额外的灵活性。

(如果看起来只需编写通用代码来获取所有数据库字段并将其放入XML文件中,请考虑这样一种情况:年龄作为出生年份存储在数据库中,您必须进行计算才能创建年龄。)

票数 6
EN

Stack Overflow用户

发布于 2011-03-15 04:27:00

当我看到程序员为了避免简单的查询而使用的长度时,比如:

代码语言:javascript
运行
复制
select * from products where productid in (1,2) and productactive = 1

或者:

代码语言:javascript
运行
复制
select * from products where not exists (
    select * from order_lines where products.id = order_lines.productid)

然后我总是想知道他们真正的目标是什么。因为它不可能是简单的。

票数 6
EN

Stack Overflow用户

发布于 2011-03-15 04:10:04

SQL就是代码,只是它不同于其他代码的编程语言。如果需要更改SQL,通常还需要更改处理该SQL、数据和数据库模式的代码。SQL不应该在不同的安装之间变化。

如果添加一个列,仅更改SQL是不够的,还需要更改处理该列的代码。几乎所有对数据库模式和SQL的更改,仅仅更改SQL是不够的。

另一方面,连接字符串是配置,而不是代码。

(是的,所有这些都有例外,如果你正在创建一个通用的报告工具,你需要设计它,以便SQL可以“可配置”)

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5303746

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档