亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pg.pm

?? bugzilla
?? PM
字號:
# -*- Mode: perl; indent-tabs-mode: nil -*-## The contents of this file are subject to the Mozilla Public# License Version 1.1 (the "License"); you may not use this file# except in compliance with the License. You may obtain a copy of# the License at http://www.mozilla.org/MPL/## Software distributed under the License is distributed on an "AS# IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or# implied. See the License for the specific language governing# rights and limitations under the License.## The Original Code is the Bugzilla Bug Tracking System.## The Initial Developer of the Original Code is Netscape Communications# Corporation. Portions created by Netscape are# Copyright (C) 1998 Netscape Communications Corporation. All# Rights Reserved.## Contributor(s): Dave Miller <davem00@aol.com>#                 Gayathri Swaminath <gayathrik00@aol.com>#                 Jeroen Ruigrok van der Werven <asmodai@wxs.nl>#                 Dave Lawrence <dkl@redhat.com>#                 Tomas Kopal <Tomas.Kopal@altap.cz>#                 Max Kanat-Alexander <mkanat@bugzilla.org>#                 Lance Larsh <lance.larsh@oracle.com>=head1 NAMEBugzilla::DB::Pg - Bugzilla database compatibility layer for PostgreSQL=head1 DESCRIPTIONThis module overrides methods of the Bugzilla::DB module with PostgreSQLspecific implementation. It is instantiated by the Bugzilla::DB moduleand should never be used directly.For interface details see L<Bugzilla::DB> and L<DBI>.=cutpackage Bugzilla::DB::Pg;use strict;use Bugzilla::Error;use DBD::Pg;# This module extends the DB interface via inheritanceuse base qw(Bugzilla::DB);use constant BLOB_TYPE => { pg_type => DBD::Pg::PG_BYTEA };sub new {    my ($class, $user, $pass, $host, $dbname, $port) = @_;    # The default database name for PostgreSQL. We have    # to connect to SOME database, even if we have    # no $dbname parameter.    $dbname ||= 'template1';    # construct the DSN from the parameters we got    my $dsn = "DBI:Pg:dbname=$dbname";    $dsn .= ";host=$host" if $host;    $dsn .= ";port=$port" if $port;    # This stops Pg from printing out lots of "NOTICE" messages when    # creating tables.    $dsn .= ";options='-c client_min_messages=warning'";    my $self = $class->db_new($dsn, $user, $pass);    # all class local variables stored in DBI derived class needs to have    # a prefix 'private_'. See DBI documentation.    $self->{private_bz_tables_locked} = "";    bless ($self, $class);    return $self;}# if last_insert_id is supported on PostgreSQL by lowest DBI/DBD version# supported by Bugzilla, this implementation can be removed.sub bz_last_key {    my ($self, $table, $column) = @_;    my $seq = $table . "_" . $column . "_seq";    my ($last_insert_id) = $self->selectrow_array("SELECT CURRVAL('$seq')");    return $last_insert_id;}sub sql_regexp {    my ($self, $expr, $pattern) = @_;    return "$expr ~* $pattern";}sub sql_not_regexp {    my ($self, $expr, $pattern) = @_;    return "$expr !~* $pattern" }sub sql_limit {    my ($self, $limit, $offset) = @_;    if (defined($offset)) {        return "LIMIT $limit OFFSET $offset";    } else {        return "LIMIT $limit";    }}sub sql_from_days {    my ($self, $days) = @_;    return "TO_TIMESTAMP(${days}::int, 'J')::date";}sub sql_to_days {    my ($self, $date) = @_;    return "TO_CHAR(${date}::date, 'J')::int";}sub sql_date_format {    my ($self, $date, $format) = @_;        $format = "%Y.%m.%d %H:%i:%s" if !$format;    $format =~ s/\%Y/YYYY/g;    $format =~ s/\%y/YY/g;    $format =~ s/\%m/MM/g;    $format =~ s/\%d/DD/g;    $format =~ s/\%a/Dy/g;    $format =~ s/\%H/HH24/g;    $format =~ s/\%i/MI/g;    $format =~ s/\%s/SS/g;    return "TO_CHAR($date, " . $self->quote($format) . ")";}sub sql_interval {    my ($self, $interval, $units) = @_;        return "$interval * INTERVAL '1 $units'";}sub sql_string_concat {    my ($self, @params) = @_;        # Postgres 7.3 does not support concatenating of different types, so we    # need to cast both parameters to text. Version 7.4 seems to handle this    # properly, so when we stop support 7.3, this can be removed.    return '(CAST(' . join(' AS text) || CAST(', @params) . ' AS text))';}sub bz_lock_tables {    my ($self, @tables) = @_;       my $list = join(', ', @tables);    # Check first if there was no lock before    if ($self->{private_bz_tables_locked}) {        ThrowCodeError("already_locked", { current => $self->{private_bz_tables_locked},                                           new => $list });    } else {        my %read_tables;        my %write_tables;        foreach my $table (@tables) {            $table =~ /^([\d\w]+)([\s]+AS[\s]+[\d\w]+)?[\s]+(WRITE|READ)$/i;            my $table_name = $1;            if ($3 =~ /READ/i) {                if (!exists $read_tables{$table_name}) {                    $read_tables{$table_name} = undef;                }            }            else {                if (!exists $write_tables{$table_name}) {                    $write_tables{$table_name} = undef;                }            }        }            # Begin Transaction        $self->bz_start_transaction();                Bugzilla->dbh->do('LOCK TABLE ' . join(', ', keys %read_tables) .                          ' IN ROW SHARE MODE') if keys %read_tables;        Bugzilla->dbh->do('LOCK TABLE ' . join(', ', keys %write_tables) .                          ' IN ROW EXCLUSIVE MODE') if keys %write_tables;        $self->{private_bz_tables_locked} = $list;    }}sub bz_unlock_tables {    my ($self, $abort) = @_;        # Check first if there was previous matching lock    if (!$self->{private_bz_tables_locked}) {        # Abort is allowed even without previous lock for error handling        return if $abort;        ThrowCodeError("no_matching_lock");    } else {        $self->{private_bz_tables_locked} = "";        # End transaction, tables will be unlocked automatically        if ($abort) {            $self->bz_rollback_transaction();        } else {            $self->bz_commit_transaction();        }    }}# Tell us whether or not a particular sequence exists in the DB.sub bz_sequence_exists {    my ($self, $seq_name) = @_;    my $exists = $self->selectrow_array(        'SELECT 1 FROM pg_statio_user_sequences WHERE relname = ?',        undef, $seq_name);    return $exists || 0;}###################################################################### Custom Database Setup#####################################################################sub bz_setup_database {    my $self = shift;    $self->SUPER::bz_setup_database(@_);    # PostgreSQL doesn't like having *any* index on the thetext    # field, because it can't have index data longer than 2770    # characters on that field.    $self->bz_drop_index('longdescs', 'longdescs_thetext_idx');    # PostgreSQL also wants an index for calling LOWER on    # login_name, which we do with sql_istrcmp all over the place.    $self->bz_add_index('profiles', 'profiles_login_name_lower_idx',         {FIELDS => ['LOWER(login_name)'], TYPE => 'UNIQUE'});    # Now that Bugzilla::Object uses sql_istrcmp, other tables    # also need a LOWER() index.    _fix_case_differences('fielddefs', 'name');    $self->bz_add_index('fielddefs', 'fielddefs_name_lower_idx',        {FIELDS => ['LOWER(name)'], TYPE => 'UNIQUE'});    _fix_case_differences('keyworddefs', 'name');    $self->bz_add_index('keyworddefs', 'keyworddefs_name_lower_idx',        {FIELDS => ['LOWER(name)'], TYPE => 'UNIQUE'});    _fix_case_differences('products', 'name');    $self->bz_add_index('products', 'products_name_lower_idx',        {FIELDS => ['LOWER(name)'], TYPE => 'UNIQUE'});    # bz_rename_column didn't correctly rename the sequence.    if ($self->bz_column_info('fielddefs', 'id')        && $self->bz_sequence_exists('fielddefs_fieldid_seq'))     {        print "Fixing fielddefs_fieldid_seq sequence...\n";        $self->do("ALTER TABLE fielddefs_fieldid_seq RENAME TO fielddefs_id_seq");        $self->do("ALTER TABLE fielddefs ALTER COLUMN id                    SET DEFAULT NEXTVAL('fielddefs_id_seq')");    }}# Renames things that differ only in case.sub _fix_case_differences {    my ($table, $field) = @_;    my $dbh = Bugzilla->dbh;    my $duplicates = $dbh->selectcol_arrayref(          "SELECT DISTINCT LOWER($field) FROM $table         GROUP BY LOWER($field) HAVING COUNT(LOWER($field)) > 1");    foreach my $name (@$duplicates) {        my $dups = $dbh->selectcol_arrayref(            "SELECT $field FROM $table WHERE LOWER($field) = ?",            undef, $name);        my $primary = shift @$dups;        foreach my $dup (@$dups) {            my $new_name = "${dup}_";            # Make sure the new name isn't *also* a duplicate.            while (1) {                last if (!$dbh->selectrow_array(                             "SELECT 1 FROM $table WHERE LOWER($field) = ?",                              undef, lc($new_name)));                $new_name .= "_";            }            print "$table '$primary' and '$dup' have names that differ",                  " only in case.\nRenaming '$dup' to '$new_name'...\n";            $dbh->do("UPDATE $table SET $field = ? WHERE $field = ?",                     undef, $new_name, $dup);        }    }}###################################################################### Custom Schema Information Functions###################################################################### Pg includes the PostgreSQL system tables in table_list_real, so # we need to remove those.sub bz_table_list_real {    my $self = shift;    my @full_table_list = $self->SUPER::bz_table_list_real(@_);    # All PostgreSQL system tables start with "pg_" or "sql_"    my @table_list = grep(!/(^pg_)|(^sql_)/, @full_table_list);    return @table_list;}1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色婷婷久久99综合精品jk白丝| 精品乱人伦一区二区三区| 色婷婷久久久亚洲一区二区三区| 91精品欧美福利在线观看| 久久久九九九九| 三级一区在线视频先锋 | 国产一区二区三区免费观看 | 久久91精品久久久久久秒播| 成人精品免费视频| 欧美成人三级在线| 一区二区三区欧美日| 国内精品第一页| 7777精品伊人久久久大香线蕉完整版 | 国产资源精品在线观看| 色婷婷一区二区| 国产三级欧美三级日产三级99| 亚洲国产精品一区二区www在线| 欧美性猛片xxxx免费看久爱| 日韩精品一区二区在线观看| 一区二区三区免费网站| 国产经典欧美精品| 日韩精品一区二| 人人爽香蕉精品| 欧美日韩成人在线一区| 一区二区三区四区蜜桃 | 在线观看一区日韩| 国产精品素人视频| 国产一区日韩二区欧美三区| 91精品国产综合久久久久久久| 一区二区三区在线不卡| 91女神在线视频| 亚洲日本韩国一区| 色呦呦网站一区| 亚洲自拍偷拍欧美| 欧美亚洲国产怡红院影院| 国产精品福利一区二区三区| 成人午夜短视频| 国产精品久久一级| 99精品久久免费看蜜臀剧情介绍| 国产欧美综合在线观看第十页 | 日韩二区在线观看| 欧美高清你懂得| 日韩av一级电影| 欧美成人艳星乳罩| 国产乱码精品一区二区三区忘忧草 | 免费成人在线播放| 亚洲精品一区二区三区香蕉| 国产做a爰片久久毛片| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 精品美女一区二区三区| 激情五月婷婷综合网| www精品美女久久久tv| 国产传媒欧美日韩成人| 国产精品亲子伦对白| 99麻豆久久久国产精品免费 | 久久综合狠狠综合久久综合88 | 日韩二区在线观看| 精品国产91久久久久久久妲己| 精品综合免费视频观看| 国产欧美日韩中文久久| 色香蕉久久蜜桃| 日本不卡一二三区黄网| 精品国产乱码91久久久久久网站| 国产成人在线视频免费播放| 日韩一区有码在线| 欧美精品一卡二卡| 国产风韵犹存在线视精品| 自拍偷拍国产精品| 一区二区高清在线| 日韩一区二区麻豆国产| 丁香五精品蜜臀久久久久99网站| 悠悠色在线精品| 精品少妇一区二区三区在线播放 | 91成人免费在线| 美国三级日本三级久久99| 中文字幕av一区 二区| 欧美亚洲动漫精品| 国产在线播放一区三区四| 亚洲欧洲一区二区在线播放| 欧美人与性动xxxx| 国产999精品久久久久久| 亚洲一区二区三区不卡国产欧美| 精品国产91乱码一区二区三区| 91福利国产成人精品照片| 国产乱码字幕精品高清av | 亚洲精品一区二区三区蜜桃下载| 成人午夜碰碰视频| 日韩精品一二三四| 亚洲欧美激情小说另类| 2020国产精品| 91精品综合久久久久久| 丁香天五香天堂综合| 视频在线观看一区| 亚洲精品少妇30p| 久久久久久黄色| 91精品国产福利在线观看| 99综合影院在线| 国产成人精品aa毛片| 日韩精品久久理论片| 一区二区三区蜜桃网| 欧美国产亚洲另类动漫| 日韩精品在线看片z| 欧美亚州韩日在线看免费版国语版| 国产一区999| 美国十次了思思久久精品导航| 亚洲国产精品精华液网站| 中文字幕一区二区三区四区| 欧美大片国产精品| 91精品国产综合久久蜜臀| 欧美系列在线观看| 一本一本大道香蕉久在线精品| 不卡一区中文字幕| 成人网男人的天堂| 国产盗摄女厕一区二区三区| 久草中文综合在线| 激情综合网av| 国产一区二区三区在线观看免费视频| 久久国产精品一区二区| 玖玖九九国产精品| 久久99精品久久久久| 久久电影网站中文字幕| 韩国中文字幕2020精品| 黄色日韩网站视频| 国产精品中文字幕一区二区三区| 国产精品一区二区在线播放 | 97久久精品人人澡人人爽| 成人蜜臀av电影| 99久久精品免费观看| 成年人国产精品| 91福利国产精品| 欧美日韩亚洲另类| 欧美一区二区在线免费观看| 8v天堂国产在线一区二区| 91精品麻豆日日躁夜夜躁| 欧美肥妇bbw| 精品国产不卡一区二区三区| 国产日韩欧美精品综合| 中文字幕欧美日本乱码一线二线| 国产欧美一区视频| 亚洲乱码中文字幕| 午夜精品久久久久久不卡8050| 五月天一区二区| 国产一区二区看久久| 成人国产精品免费网站| 色悠久久久久综合欧美99| 91精品欧美综合在线观看最新| 国产无人区一区二区三区| 亚洲人成伊人成综合网小说| 午夜视黄欧洲亚洲| 国产精品一二一区| 91久久精品午夜一区二区| 欧美一区二区在线观看| 国产女主播一区| 亚洲一区视频在线| 国内精品伊人久久久久av一坑| 99视频精品在线| 日韩一区二区三区视频在线观看| 国产精品污污网站在线观看| 亚洲一区二区三区中文字幕在线| 奇米精品一区二区三区在线观看| 成+人+亚洲+综合天堂| 欧美精品乱码久久久久久按摩| 久久精品男人天堂av| 亚洲综合色区另类av| 国精产品一区一区三区mba视频 | 国产高清精品在线| 91国产精品成人| 中文字幕第一区二区| 日韩电影网1区2区| av动漫一区二区| 久久色中文字幕| 调教+趴+乳夹+国产+精品| 成人丝袜视频网| 亚洲精品一区二区三区福利| 亚洲午夜视频在线| www.日韩av| 久久久国产精华| 另类小说综合欧美亚洲| 色综合久久久久网| 国产精品麻豆欧美日韩ww| 另类小说欧美激情| 在线播放中文字幕一区| 日韩毛片视频在线看| 国产麻豆视频一区| 日韩欧美aaaaaa| 日本中文字幕一区二区视频| 91视频观看免费| 欧美国产精品专区| 激情av综合网| 精品国产成人在线影院| 蜜臀av一区二区三区| 欧美少妇一区二区| 一区二区三区日韩在线观看| 成人免费高清在线| 中文字幕av在线一区二区三区| 国产成人av电影免费在线观看| 精品88久久久久88久久久| 日本中文字幕一区| 日韩欧美黄色影院| 久久www免费人成看片高清|