开发者社区> 问答> 正文

在Java中如何更高效地存储和管理SQL语句?

注意:使用java.util.Properties#loadFromXML其实会更简单!
如果使用的是普通的、没有任何外部类库的 Java JDBC,那么就必须得自己去管理 SQL 语句。很不幸的是,Java String 并不支持多行结构,所以开发者必须使用许多引号+连接符来拼接语句,这会使得 SQL 语句非常难于阅读和管理。同时,这也使得维护和测试(尝试从 Java 代码中 Copy 一条 SQL 语句到 SQL 客户端运行)更加困难。如果能保证整条 SQL 语句完好无缺,又避免了 Java 的干扰,那该有多好啊!
这里有个快速解决方案,把 SQL 查询语句存储在 XML 的 CDATA 里面:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<sqlMap>
<sqls>
<entry>
<key>getUser</key>
<value><![CDATA[
SELECT *
FROM USERS
WHERE ID = ?
]]></value>
</entry>
<entry>
<key>getSpecialCodeByUserId</key>
<value><![CDATA[
SELECT u.EMAIL, p.ID as PROFILEID, p.SPECIALCODE, a.MANAGERID
FROM USERS u
LEFT JOIN PROFILE p ON p.USERID = u.ID
LEFT JOIN ACCOUNT a ON a.PROFILEID = p.ID
WHERE u.ID = ?  ]]></value>
  </entry>   </sqls>
</sqlMap>
如果现在再去读 SQL 语句,开发者可以利用内建的 JAXB。
import javax.xml.bind.annotation.XmlRootElement;
import java.util.HashMap;
import java.util.Map;
@XmlRootElementpublic
class SqlMap {
Map<String, String> sqls = new HashMap<>();
public Map<String, String> getSqls() {
return sqls;
}
public void setSqls(Map<String, String> sqls) {
this.sqls = sqls;
}
public String getSql(String name) {
return sqls.get(name);
}
public static SqlMap load(String name) throws Exception {
String xml = Utils.loadString(name);
SqlMap sqlMap = unmarshallXML(xml );
return sqlMap;
}
}

OneAPM for Java 能够深入到所有 Java 应用内部完成应用性能管理和监控,包括代码级别性能问题的可见性、性能瓶颈的快速识别与追溯、真实用户体验监控、服务器监控和端到端的应用性能管理。更多详情请登录http://www.oneapm.com

展开
收起
sunny夏筱 2015-10-29 14:59:14 6777 0
3 条回答
写回答
取消 提交回答
  • apm
    Re在Java中如何更高效地存储和管理SQL语句?
    不错不错!
    排版有点乱哦,这个论坛支持语法高亮吗?
    2015-10-30 11:24:55
    赞同 展开评论 打赏
  • Re在Java中如何更高效地存储和管理SQL语句?
    不错,涨姿势了  
    2015-10-29 18:52:37
    赞同 展开评论 打赏
  • Re在Java中如何更高效地存储和管理SQL语句?
    2015-10-29 18:18:47
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Spring Cloud Alibaba - 重新定义 Java Cloud-Native 立即下载
The Reactive Cloud Native Arch 立即下载
JAVA开发手册1.5.0 立即下载