您的位置: 旅游網 > 圖庫 >> 美女模特

    基于自定義函數的

    發布時間:2021-10-29 05:43:27

    留言版上的第2330號問題是:

    在oralce中給自建函數創建索引,結果不成功。

    source:Create Index IDX_T_SP_TWOTYPESTAT_0_f On T_SP_TWOTYPESTAT_0(f_dateadd(yearmonth,12,2));

    err:the function is not deterministic.

    我們看一下這是為什么?

    單注獎金為28.59萬。當期我省達州彩民贏得幸運 隨便一個測試可以再現這個問題,我門創建一個函數(本范例函數用于進行16進制向10進制轉換):

    CREATE OR REPLACE FUNCTION h2ten (

    p_str IN VARCHAR2,

    p_from_base IN NUMBER DEFAULT 16

    )

    RETURN NUMBER

    IS

    l_num NUMBER DEFAULT 0;

    l_hex VARCHAR2 (16) DEFAULT \'ABCDEF\';

    BEGIN

    FOR i IN 1 .. LENGTH (p_str)

    LOOP

    l_num :=

    l_num * p_from_base + INSTR (l_hex, UPPER (SUBSTR (p_str, i, 1)))

    - 1;

    END LOOP;

    RETURN l_num;

    END h2ten;

    此時創建索引,獲得如下錯誤信息:

    SQL create table t as select username,\'a\' hex from dba_users;

    Table created

    SQL create index i_t on t (h2ten(hex));

    create index i_t on t (h2ten(hex))

    ORA-30553: The function is not deterministic

    如果需要創建基于自定義函數的索引,那么我們需要指定deterministic參數:

    CREATE OR REPLACE FUNCTION h2ten (

    p_str IN VARCHAR2,

    p_from_base IN NUMBER DEFAULT 16

    )

    RETURN NUMBER DETERMINISTIC

    IS

    l_num NUMBER DEFAULT 0;

    l_hex VARCHAR2 (16) DEFAULT \'ABCDEF\';

    BEGIN

    FOR i IN 1 .. LENGTH (p_str)

    LOOP

    l_num :=

    l_num * p_from_base + INSTR (l_hex, UPPER (SUBSTR (p_str, i, 1)))

    - 1;

    END LOOP;

    RETURN l_num;

    END h2ten;

    此時創建索引即可:

    SQL create index i_t on t (h2ten(hex));

    Index created

    Oracle這樣解釋這個參數:

    The hint DETERMINISTIC helps the optimizer avoid redundant function calls. If a stored function was called previously with the same arguments, the optimizer can elect to use the previous result. The function result should not depend on the state of session variables or schema objects. Otherwise, results might vary across calls. Only DETERMINISTIC functions can be called from a function-based index or a materialized view that has query-rewrite enabled.

    查看本文來源

    重慶無痛人流
    呼和浩特治療婦科哪家醫院好
    太原宮頸糜爛治療費用
    猜你會喜歡的
    猜你會喜歡的
    主站蜘蛛池模板: 国产在线视频国产永久视频| 久久久综合亚洲色一区二区三区| 青青青国产依人精品视频| 天天操天天干天天干| 久久精品WWW人人爽人人| 永久免费bbbbbb视频| 国产999视频| 四虎国产精品高清在线观看| 女人张开腿让男桶喷水高潮 | 免费国产成人高清视频网站| 黄色软件网站大全| 国产羞羞羞视频在线观看| 一本久久伊人热热精品中文| 日本电影和嫒子同居日子| 亚洲国产成人久久综合区| 男女性色大片免费网站| 国产aⅴ无码专区亚洲av麻豆| 狠狠色先锋资源网| 国产视频www| www.youjizz.com在线| 日本xxxxbbbb| 亚洲av无码国产综合专区| 深夜爽爽福利gif在线观看| 又爽又黄又无遮挡网站| 三级视频在线播放线观看| 欧美精品dorcelclub全集31| 动漫卡通精品3d一区二区| 超碰97人人做人人爱少妇| 国产精品久久影院| 99久久99久久免费精品小说| 成人3d动漫网址在线观看| 久久亚洲精品11p| 桃花视频性视频| 亚洲欧美在线观看一区二区| 真实国产伦子系| 国产一区免费在线观看| 黑人一级黄色片| 国产精品乱码一区二区三区| 99久久国产综合精品成人影院| 波多野结衣系列无限发射| 天天综合色天天综合网|