`

postgresql9.3入门

阅读更多

一、安装

首先,安装PostgreSQL客户端。

sudo apt-get install postgresql-client

然后,安装PostgreSQL服务器。

sudo apt-get install postgresql

正常情况下,安装完成后,PostgreSQL服务器会自动在本机的5432端口开启。

 

++++++++++++++密码忘记了++++++++++++++++++++

PostgreSQL默认的超级管理员密码是postgres

连接方法:

su - postgres 或 sudo su - postgres

psql -U postgres(注意,是大写的-U)默认密码为空

修改密码的方法是, 用psql登入管理:psql -U postgres

然后用这样的命令来修改密码:alter user postgres with password 'new password' 

 

++++++++++++++远程登录配置++++++++++++++++++

远程连接postgresql问题.连接不上 

 

默认下,POSTGRESQL只接受本地服务,要接受远程服务,需改2个地方 

1 vim /var/lib/pgsql/9.3/data/postgresql.conf中的listen_address改为‘*’

2 vim /var/lib/pgsql/9.3/data/pg_hba.conf 增加 1行远程的规则 

# TYPE  DATABASE    USER        CIDR-ADDRESS          METHOD 

host all all 0.0.0.0/0 ident

然后重启数据库服务:

# /etc/init.d/postgresql-9.3 restart

 

二、添加新用户和新数据库

初次安装后,默认生成一个名为postgres的数据库和一个名为postgres的数据库用户。这里需要注意的是,同时还生成了一个名为postgres的Linux系统用户。

下面,我们使用postgres用户,来生成其他用户和新数据库。好几种方法可以达到这个目的,这里介绍两种。

第一种方法,使用PostgreSQL控制台。

首先,新建一个Linux新用户,可以取你想要的名字,这里为dbuser。

sudo adduser dbuser

然后,切换到postgres用户。

sudo su - postgres

下一步,使用psql命令登录PostgreSQL控制台。

psql

这时相当于系统用户postgres以同名数据库用户的身份,登录数据库,这是不用输入密码的。如果一切正常,系统提示符会变为"postgres=#",表示这时已经进入了数据库控制台。以下的命令都在控制台内完成。

第一件事是使用\password命令,为postgres用户设置一个密码。

\password postgres

第二件事是创建数据库用户dbuser(刚才创建的是Linux系统用户),并设置密码。

CREATE USER dbuser WITH PASSWORD 'password';

第三件事是创建用户数据库,这里为exampledb,并指定所有者为dbuser。

CREATE DATABASE exampledb OWNER dbuser;

第四件事是将exampledb数据库的所有权限都赋予dbuser,否则dbuser只能登录控制台,没有任何数据库操作权限。

GRANT ALL PRIVILEGES ON DATABASE exampledb to dbuser;

最后,使用\q命令退出控制台(也可以直接按ctrl+D)。

\q

 

第二种方法,使用shell命令行。

添加新用户和新数据库,除了在PostgreSQL控制台内,还可以在shell命令行下完成。这是因为PostgreSQL提供了命令行程序createuser和createdb。还是以新建用户dbuser和数据库exampledb为例。

首先,创建数据库用户dbuser,并指定其为超级用户。

sudo -u postgres createuser --superuser dbuser

然后,登录数据库控制台,设置dbuser用户的密码,完成后退出控制台。

sudo -u postgres psql

\password dbuser

\q

接着,在shell命令行下,创建数据库exampledb,并指定所有者为dbuser。

sudo -u postgres createdb -O dbuser exampledb

 

三、登录数据库

添加新用户和新数据库以后,就要以新用户的名义登录数据库,这时使用的是psql命令。

psql -U dbuser -d exampledb -h 127.0.0.1 -p 5432

上面命令的参数含义如下:-U指定用户,-d指定数据库,-h指定服务器,-p指定端口。

输入上面命令以后,系统会提示输入dbuser用户的密码。输入正确,就可以登录控制台了。

psql命令存在简写形式。如果当前Linux系统用户,同时也是PostgreSQL用户,则可以省略用户名(-U参数的部分)。举例来说,我的Linux系统用户名为ruanyf,且PostgreSQL数据库存在同名用户,则我以ruanyf身份登录Linux系统后,可以直接使用下面的命令登录数据库,且不需要密码。

 

另外,如果要恢复外部数据,可以使用下面的命令。

psql exampledb < exampledb.sql

psql -p 5432 -U postgres -d mango15 -f /tmp/public.sql

 

四、控制台命令

除了前面已经用到的\password命令(设置密码)和\q命令(退出)以外,控制台还提供一系列其他命令。

\h:查看SQL命令的解释,比如\h select。

\?:查看psql命令列表。

\l:列出所有数据库。

\c [database_name]:连接其他数据库。

\d:列出当前数据库的所有表格。

\d [table_name]:列出某一张表格的结构。

\du:列出所有用户。

\e:打开文本编辑器。

\conninfo:列出当前数据库和连接的信息。

 

五、数据库操作

# 创建新表 

CREATE TABLE user_tbl(name VARCHAR(20), signup_date DATE);

# 插入数据 

INSERT INTO user_tbl(name, signup_date) VALUES('张三', '2013-12-22');

# 选择记录 

SELECT * FROM user_tbl;

# 更新数据 

UPDATE user_tbl set name = '李四' WHERE name = '张三';

# 删除记录 

DELETE FROM user_tbl WHERE name = '李四' ;

# 添加栏位 

ALTER TABLE user_tbl ADD email VARCHAR(40);

# 更新结构 

ALTER TABLE user_tbl ALTER COLUMN signup_date SET NOT NULL;

# 更名栏位 

ALTER TABLE user_tbl RENAME COLUMN signup_date TO signup;

# 删除栏位 

ALTER TABLE user_tbl DROP COLUMN email;

# 表格更名 

ALTER TABLE user_tbl RENAME TO backup_tbl;

# 删除表格 

DROP TABLE IF EXISTS backup_tbl;

 

六、创建数据库

createdb -p 5432 -e mango15

createdb -p 5432 -e -U postgres mango15

连接数据库:

psql -p 5432 -U postgres -d mango15

 

 本人博客已搬家,新地址为:http://www.pycoding.com/

 

分享到:
评论

相关推荐

    PostgreSQL9.3 DBA最佳实战培训PPT 580页

    零基础PostgreSQL9.3 DBA最佳实战培训PPT 580页,适合新手入门到运维PostgreSQL数据库系统。

    PostgreSQL全套课程

    PostgreSQL全套课程,全套24.73G,包含免密视频、课件、相关文档,课程目录: 01.PostgreSQL9 从零开始学...03.PostgreSQL 9.3 DBA5天培训 24课 04.PostgreSQL 9.3 优化培训视频 19课 05.DBA团队每天16点技术分享 7课

    play-heroku-seed:用于 Play、Heroku 和 Postgres 的 Seed 应用程序,带有演示 CRUD 模型、视图、控制器

    安装 PostgreSQL 9.3 Postgres.app 是最简单的方法: 运行psql 设置开发数据库,​​注意下划线: CREATE DATABASE play_heroku_seed; 通过查看数据库列表确认已创建数据库\l 运行应用程序 在 repo 的根文件夹中:...

    banyan-web:协作的社会经验

    适用于数据库的PostgreSQL 9.3。 Amazon S3用于媒体存储,SNS用于推送通知。 要开始为这个项目做贡献: 创建一个virtualenv(推荐)并激活它 在所需(virtualenv)目录中克隆此git repo 安装需求(pip install ...

    超级市场:厨师的社区平台

    :用于构建RPM和DEB软件包的代码要求Ruby 2.6.6 PostgreSQL 9.3 Redis的2.4+发展历程配置中将密钥和机密配置为。 有关启动和运行所需的密钥和机密的信息,请参见.env.example 。 详细介绍了使超市在本地运行所需的...

    精通Odoo开发和使用

    9.3 导出或导入数据文件 77 9.4 快捷输入标签 78 9.5 用 field 标签设置值 78 9.5.1 eval 语法 78 9.5.2 ref 属性 79 9.5.3 One2many 和 Many2many 的 eval 赋值 79 10 Odoo 开发基础: 请假模块第二谈 81 10.1 本例...

    Linux环境数据库管理员指南

    9.3 获得Postgre SQL 253 9.4 PostgreSQL 快速安装说明 254 9.5 详细安装 255 9.6 资源分发包的安装 259 9.6.1 准备工作 259 9.6.2 循序渐进的过程 260 9.7 PostgreSQL样例 RPM 264 9.8 测试Tcl/Tk接口 264 9.9 测试...

    SQL必知必会(第3版-PDF清晰版)part1

    推荐:学习SQL编程,必备书籍,从入门到进阶/精通,实例与理论同步,比较优秀作品!(共分压5部分)目录: 第1章 了解SQL... 1 1.1 数据库基础..... 1 1.1.1 什么是数据库..... 2 1.1.2 表..... 2 1.1.3 列和...

    spring security 参考手册中文版

    40.3.2 PostgreSQL 277 40.3.3 MySQL和MariaDB 278 40.3.4 Microsoft SQL Server 279 40.3.5 Oracle数据库 280 41.安全命名空间 282 41.1 Web应用程序安全性 282 41.1.1 &lt;debug&gt; 282 41.1.2 &lt;http&gt; 282 属性 283 的...

Global site tag (gtag.js) - Google Analytics