In a SQL SELECT
statement, I'd like to execute a function that is deterministic for the scope of that SELECT
statement (or transaction would be ok, too):
select t.x, t.y, my_function(t.x) from t
Many values of t.x
are the same so Oracle could omit calling the same function again and again, to speed things up. But if I label the function as DETERMINISTIC
, the results may be cached between several executions of this query. The reason why I can't use DETERMINISTIC
is because my_function
uses a configuration parameter that is changed from time to time.
Is there any other keyword I could use? Are there any catches that I should be aware of (memory issues, concurrency, etc)? Or maybe any other tricks, such as analytic functions to call the function only once per t.x
value (without major performance impact)?
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…