oracle索引

大家好,请问在oracle中这个SQL语句该怎样建立索引?谢谢
"SELECT fd_name FROM oa_system_notify "+" where fd_receive_login='"+UserUtil.getUser().getFdLoginName()+"'"; 其中UserUtil.getUser().getFdLoginName()是登入某个系统的用户名,是随登入名不同动态变化的,谢谢 ,现在在程序中直接执行这条SQL语句非常慢,所以想用索引,不知该怎样建立索引,并且通过索引能否提高效率?或者还有什么确实可行的提高效率方式?谢谢

  1. 当一个查询条件指定后,查询结果的范围能缩小到 5%,那么建立索引才有实质性的效果。

以你的查询为例,如果在表oa_system_notify 中,有100条数据,通过fd_receive_login=? 可以唯一确定一条数据(应该是这样的吧),那么在列fd_receive_login上建立索引,可以极大提高查询效率

  1. 复合索引的建立

create index 索引名 on 表名(列名1,列名2);

我们一般称[列名1]为主索引,也就是说 where 条件中,必须有[列名1 = ?],否则索引无效

  1. 查询一条查询语句是否使用了索引,可以通过【执行计划】查看,工具和相关的方法有很多,自己找找吧~非常有用的

CREATE INDEX 索引名 ON 表名 (列名)

看看直接执行sql,效率怎么样?
不要直接拼sql,要用prepare