zoukankan      html  css  js  c++  java
  • Postgres 数据库安装、配置、备份还原及存储过程

    一、前提
    1、CenTos操作系统,安装系统时选择安装Postgres数据库。
    二、安装数据库及配置
    1、初始化数据库TestDB
          由于安装系统时选择安装了Postgres数据库,因此系统自带postgres用户名,该用户名是针对Postgres数据库的管理员。
    (1)使用系统自带的数据库用户名称postgres,在root权限下执行。
    mkdir /usr/local/pgsql/data
    chown postgres /usr/local/pgsql/data
    su postgres
    initdb –D /usr/local/pgsql/data
                    postmaster –D /usr/local/pgsql/data/ &
    (2)手动创建数据库用户名称,比如postgresql ,在root权限下执行。
    adduser postgresql
    mkdir /usr/local/pgsql/data
    chown postgresql /usr/local/pgsql/data
    su postgresql
    initdb –D /usr/local/pgsql/data
                   postmaster –D /usr/local/pgsql/data/ &
    2、配置数据库文件
    (1)root权限下进如pgsql下的data目录,修改pg_hba.conf,在其后追加内容如下,其中IP为数据库服务器的IP地址。
               host  all  all  192.168.0.1/24   md5
    (2)修改同一目录下的postgresql.conf文件,去掉文件listen_address和port前的#号,然后修改
               listen_address = '*'
    (3)使用postgres或postgresql管理员添加用户postuser及对应密码。
    经过这样配置,就可以使用postuser及密码远程连接服务器了。
    3、初始化数据库TestDB
    (1)切换到postgres用户下,创建数据库
              createdb TestDB;
    (2)进入数据库
              psql TestDB
    4、备份及还原数据库
    (1)切换到数据库用户postgres下,执行下面命令:
    备份:Pg_dump –h localhost –U postgres –n public –Ft TestDB > /home/postgres/[名称].tar
    还原:
    切换到数据库用户postgresql下,先删除原数据库"TestDB"(如果存在),再以"TestDB"的名称重新建立数据库,执行下面命令
    psql TestDB
    create language plpgSQL;
    \q
    pg_restore –h localhost –U postgres –d TestDB [路径]/ [名称].tar
    vacuumdb -a –z
    5、添加用户postuser
            createuser postuser -P
    6、开机自启动数据库

    <!--[if !supportLists]-->(1)    用root用户登录服务器,然后切换到/etc/rc.d/目录下。<!--[endif]-->
    <!--[if !supportLists]-->(2)    使用vi命令打开rc.local文件,在其后追加命令如下:<!--[endif]-->
    su - postgresql -c "postmaster -D /usr/local/pgsql/data/&"

    7、存储过程
    (1)存储过程以plpgsql语言书写,因此在书写存储过程前,先把plpgsql语言安装进数据库TestDB中。
            psql TestDB
                     create language plpgSQL;
    (2)创建表举例
    Create TABLE "CallRecordTable"
    (
    "CallIndex" INTEGER PRIMARY KEY,
    "CallerNumber" VARCHAR(32) NOT NULL DEFAULT 'anonymous',
    "CalleeNumber" VARCHAR(32) NOT NULL DEFAULT 'anonymous',
    "StartTime" VARCHAR(16) NOT NULL,
    "StopTime" VARCHAR(16) NOT NULL,
    "StoreFlag" SMALLINT NOT NULL CONSTRAINT Record_Flag_Value CHECK("StoreFlag" >= 1 AND "StoreFlag" <= 10) DEFAULT 1,
    "ReGenrationID" VARCHAR(32) NOT NULL REFERENCES "RegenServiceInfoTable" ("ReGenrationID") ON Delete CASCADE ON Update CASCADE,
    CONSTRAINT Caller_Start_OnlyOne UNIQUE("CallerNumber","StartTime"),
    CONSTRAINT Callee_Start_OnlyOne UNIQUE("CalleeNumber","StartTime"),
    CHECK("StartTime" <= "StopTime")
    );
    (3)创建存储过程举例
    Create or REPLACE FUNCTION "funSelectRecordByDateCall"(Number VARCHAR(32),StartTime VARCHAR(16),EndTime VARCHAR(16))
    RETURNS refcursor AS
    $$
    DECLARE recordcur refcursor;
    BEGIN
    OPEN recordcur FOR
    Select
        "CallIndex",
        "CallerNumber",
        "CalleeNumber",
        TO_TIMESTAMP("StartTime",'YYYYMMDDHH24MISS') AS "StartTime",
        TO_TIMESTAMP("StopTime",'YYYYMMDDHH24MISS') AS "StopTime",
        ( TO_TIMESTAMP("StopTime",'YYYYMMDDHH24MISS') - TO_TIMESTAMP("StartTime",'YYYYMMDDHH24MISS') ) AS "ContinuingTime",
        "StoreFlag",
        CR."ReGenrationID",
        "Ip",
        "Port"
    FROM
        "CallRecordTable" AS CR,
        "RegenServiceInfoTable" AS RS
    Where
        ( "StartTime" BETWEEN StartTime AND EndTime )
        AND( "CallerNumber" = Number )
        AND( CR."ReGenrationID" = RS."ReGenrationID" )
        or( "StartTime" BETWEEN StartTime AND EndTime )
        AND( "CalleeNumber" = Number )
        AND( CR."ReGenrationID" = RS."ReGenrationID" )
    orDER BY "StartTime" DESC;
    RETURN recordcur;
    END;
    $$
    LANGUAGE PLpgSQL;
    本文来自http://bbs.chinaunix.net/thread-1816035-1-13.html

    CSDN博客,转载请标明出处:http://blog.csdn.net/zst126/archive/2007/10/31/1859608.aspx

  • 相关阅读:
    一个有趣的js现象
    根相对路径的简单例子
    几道简单有趣的js题(一)
    js流程控制题——如何实现一个LazyMan
    HTML5 十大新特性(十)——Web Socket
    HTML5 十大新特性(九)——Web Storage
    HTML5 十大新特性(八)——Web Worker
    HTML5 十大新特性(七)——拖放API
    HTML5 十大新特性(六)——地理定位
    HTML5 十大新特性(五)——SVG绘图
  • 原文地址:https://www.cnblogs.com/dview112/p/2733964.html
Copyright © 2011-2022 走看看