我有一个字符串可以保存任何类型的sql语句(选择、更新、删除、插入)
我想大写该语句中的列名和表名。
假设我们有:
select id from person where name="Dave"我想要
select ID from PERSON where NAME="Dave"到目前为止,我已经在Java中找到了一些Sql解析器,但我想知道是否还有更快、更简单的方法来解析和重建sql。
编辑
为了进一步澄清这个问题,数据库整理是土耳其语,而我试图解决的问题是“土耳其I问题”。DB中的列/表的名称都是大写的,但是Java应用程序生成带有小写列和表的sql语句
发布于 2016-04-05 12:09:08
您应该在绑定变量中使用准备好的语句。通过这样做,您可以大写您的查询,然后将绑定变量放在您想要的任何情况下。
例如:
String query = "select id from person where name=?"
Connection con = .... ;
PreparredStatement ps = con.prepareStatement(query.toUpperCase());
ps.setString(1, "Dave");
ResultSet rs = ps.executeQuery();希望这能有所帮助。
发布于 2016-04-05 11:56:11
我不确定我是否正确地理解了您的问题,但是如果您想检索大写的特定列名,那么您的查询应该是,
SELECT id AS ID FROM person WHERE name = "Dave";发布于 2016-04-05 12:37:27
你可以这样做:
public String queryText(final String message, final String... args) {
return String.format(message.toUpperCase().replace("?", "%s") + "%n", args);
}然后这样称呼它:
System.out.println(queryText("select id from person where name=?", "Dave"));输出:从NAME=Dave所在的人员中选择ID
希望它能帮上忙
https://stackoverflow.com/questions/36425506
复制相似问题