大家好,请问在oracle中这个SQL语句该怎样建立索引?谢谢
"SELECT fd_name FROM oa_system_notify "+" where fd_receive_login='"+UserUtil.getUser().getFdLoginName()+"'"; 其中UserUtil.getUser().getFdLoginName()是登入某个系统的用户名,是随登入名不同动态变化的,谢谢 ,现在在程序中直接执行这条SQL语句非常慢,所以想用索引,不知该怎样建立索引,并且通过索引能否提高效率?或者还有什么确实可行的提高效率方式?谢谢
以你的查询为例,如果在表oa_system_notify 中,有100条数据,通过fd_receive_login=? 可以唯一确定一条数据(应该是这样的吧),那么在列fd_receive_login上建立索引,可以极大提高查询效率
create index 索引名 on 表名(列名1,列名2);
我们一般称[列名1]为主索引,也就是说 where 条件中,必须有[列名1 = ?],否则索引无效
CREATE INDEX 索引名 ON 表名 (列名)
看看直接执行sql,效率怎么样?
不要直接拼sql,要用prepare