首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在sql语句(Java)中使用大写的列名和表名?

如何在sql语句(Java)中使用大写的列名和表名?
EN

Stack Overflow用户
提问于 2016-04-05 11:46:14
回答 3查看 1.8K关注 0票数 0

我有一个字符串可以保存任何类型的sql语句(选择、更新、删除、插入)

我想大写该语句中的列名和表名。

假设我们有:

代码语言:javascript
复制
select id from person where name="Dave"

我想要

代码语言:javascript
复制
 select ID from PERSON where NAME="Dave"

到目前为止,我已经在Java中找到了一些Sql解析器,但我想知道是否还有更快、更简单的方法来解析和重建sql。

编辑

为了进一步澄清这个问题,数据库整理是土耳其语,而我试图解决的问题是“土耳其I问题”。DB中的列/表的名称都是大写的,但是Java应用程序生成带有小写列和表的sql语句

EN

回答 3

Stack Overflow用户

发布于 2016-04-05 12:09:08

您应该在绑定变量中使用准备好的语句。通过这样做,您可以大写您的查询,然后将绑定变量放在您想要的任何情况下。

例如:

代码语言:javascript
复制
 String query = "select id from person where name=?"
 Connection con = .... ;
 PreparredStatement ps = con.prepareStatement(query.toUpperCase());
 ps.setString(1, "Dave");

 ResultSet rs = ps.executeQuery();

希望这能有所帮助。

票数 1
EN

Stack Overflow用户

发布于 2016-04-05 11:56:11

我不确定我是否正确地理解了您的问题,但是如果您想检索大写的特定列名,那么您的查询应该是,

代码语言:javascript
复制
SELECT id AS ID FROM person WHERE name = "Dave";
票数 0
EN

Stack Overflow用户

发布于 2016-04-05 12:37:27

你可以这样做:

代码语言:javascript
复制
public String queryText(final String message, final String... args) {
    return String.format(message.toUpperCase().replace("?", "%s") + "%n", args);
}

然后这样称呼它:

代码语言:javascript
复制
System.out.println(queryText("select id from person where name=?", "Dave"));

输出:从NAME=Dave所在的人员中选择ID

希望它能帮上忙

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

https://stackoverflow.com/questions/36425506

复制
相关文章

相似问题

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