热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Windows系统中postgreSQL数据库命令的使用方法

本文主要是在windows系统下用psql进行的。注意:如果以缺省的用户postgres进入系统,为安全考虑,是不能执行某些操作的;如果要执行SQL等一些操作,必须要以另外的用户进入才行。一、进入PostgreSQL的命令可以用安装目录下的/scripts中的runpslq.bat批处

本文主要是在windows系统下用psql进行的。

注意:如果以缺省的用户postgres进入系统,为安全考虑,是不能执行某些操作的;如果要执行SQL等一些操作,必须要以另外的用户进入才行。

一、进入PostgreSQL的命令

      可以用安装目录下的/scripts中的runpslq.bat批处理文件进入。

二、查看PostgreSQL中有多少个数据库

      用命令/l可以显示当前数据库服务器中所有的数据库名。

三、改变当前数据库

      /c 数据库名

四、新建一个数据库

      create database 数据库名;

五、查看所有的用户

      /du

六、新建用户

      create user 用户名;

七、查看数据库中的表

      /d

八、新建一个数据表

      例如:

      CREATE TABLE weather (
  test(#         city      varchar(80),
  test(#         temp_lo    int,     -- 最低气温
  test(#         temp_hi    int,     -- 最高气温
  test(#         prcp      real,     -- 降水量
  test(#         date      date
  test(#           );

九、显示表结构

      /d  表名;

十、用户管理

      1、建立一个带密码、有创建数据库权限的用户:create user username password 'password' createdb;

      2、删除一个用户:drop user username;

      3、更改用户属性:alter user username [createdb] [nocreatedb] [createuser] [nocreateuser] [in group groupname] [valid until 'month day year'],其中valid until 是设置有效期,格式是'月 日 年'。

十一、组的管理

      和 Unix 里一样,组是一个逻辑上对用户分组,进而简化权限管理的方法∶ 权限可以赋予整个组,也可以对整个组撤除. 要创建一个组,使用

      CREATE GROUP name,

      要向组中增加用户或删除用户,用

      ALTER GROUP name ADD USER uname1, ...
  ALTER GROUP name DROP USER uname1, ...
十二、用户、组及权限

      1. 数据库用户
  2. 用户属性
  3. 组
  4. 权限
  5. 函数和触发器
  每个数据库集群都包含一个数据库用户的集合。 这些用户是和那些在同一个服务器上运行的操作系统的用户相独立的。 用户拥有数据库对象(比如说,表)以及可以把这些对象的权限赋予 其它用户,这样就能控制谁可以访问哪些对象。
  本章描述如何创建和管理用户,以及介绍权限系统。 有关各种类型的数据库对象和权限的效果可以在 PostgreSQL 7.3 用户手册 中找到。
  1. 数据库用户
  数据库用户从概念上与操作系统用户是完全无关的. 在实际使用中把它们对应起来可能比较方便,但不是必须的. 数据库用户名在整个数据库集群中是全局的(而不是每个库不同). 要创建一个用户,使用 SQL 命令 CREATE USER:
  CREATE USER name
  name 遵循 SQL 标识的规则: 要么完全没有特殊字符,要么用双引号引起. 要删除一个现有用户,使用类似的命令 DROP USER:
  DROP USER name
  为了方便,shell 脚本createuser和 dropuser 提供了对了这些 SQL 命令的封装. 我们可以在 shell 命令上直接调用它们:
  createuser name
  dropuser name
  为了能初创数据库系统,新建立的数据库总是包含一个预定义的用户. 这个用户将有固定的 ID 1,并且缺省时(除非在运行 initdb 时更改过)他将和 初始化该数据库集群的用户有相同的名称。 通常,这个用户叫postgres. 为了创建更多用户,你必须首先以这个初始用户身份联接.
  一个和数据库的活跃连接只能有一个用户身份进行。 和特定数据库联接的用户名是由初始化联接请求的应用以应用相关的方式声明的, 比如,psql 程序使用-U命令行选项声明它代表的进行联接 的用户.许多应用以当前操作系统的用户名为缺省(这样的应用包括 createuser 和 psql)。 这样我们就可以很方便地维护这两个用户集合之间地映射关系。
  一个客户端联接可以用来联接的数据库用户集合是由客户 认证设置决定的,在 Chapter 4 里面有解释.(因此,一个客户端并不局限于以它的操作系统用户 同名的用户进行联接,就象你登录系统的名称不一定要是你的真实 名称一样.)因为用户地身份决定了一个已连接地客户端可用的权限, 所以在多用户环境里仔细配置这些内容是非常重要的。
  2. 用户属性
  一个数据库用户可以有一系列属性,这些属性定义他的权限,以及与 客户认证系统的交互.
  superuser(超级用户)
  数据库超级用户超越所有权限检查.同样,只有超级用户才能 创建新的用户.要创建数据库超级用户,用 CREATE USER name CREATEUSER.
  database creation(创建数据库)
  用户要想创建数据库,必须明确给出权限(对于超级用户是例外,因为 他们超越所有权限检查).要创建这样的用户,用 CREATE USER name CREATEDB.
  password(口令)
  只有在对客户认证方法要求客户在与数据库建立连接是使用口令的时候,口令才比较重要. password,md5,和 crypt 认证方法使用口令。 数据库口令与操作系统口令是无关的.在创建用户的时候 声明一个口令是这样: CREATE USER name PASSWORD 'string'.
  一个用户的属性可以在创建后用 ALTER USER 修改. 参考 CREATE USER 和 ALTER USER 的手册获取细节.
  一个用户也可以为许多运行时配置设置个人缺省, 那些配置在 Section 3.4 里描述。 比如,如果出于某种原因你想在所有你做的连接中关闭索引扫描(提示:不是个好主意), 你可以用
  ALTER USER myname SET enable_indexscan TO off;
  这样就会保存该设置(但是不是立即设置)并且在随后的连接中就好像 在会话开始之后都马上 SET enable_indexscan TO off;了一样。 你也可以在会话中修改这个设置;它只是缺省。要撤销任何这样的设置, 使用 ALTER USER username RESET varname;。
  3. 组
  和 Unix 里一样,组是一个逻辑上对用户分组,进而简化权限管理的方法∶ 权限可以赋予整个组,也可以对整个组撤除. 要创建一个组,使用
  CREATE GROUP name
  要向组中增加用户或删除用户,用
  ALTER GROUP name ADD USER uname1, ...
  ALTER GROUP name DROP USER uname1, ...
  4. 权限
  当创建一个数据库对象时,它属于一个用户.该用户就是执行创建 命令的那位.要改变一个表,索引,序列,或者视图的所有者,使用 ALTER TABLE 命令。 缺省时,只有所有者(或者超级用户)可以对该对象做任何事情.为了 让别的用户也能用它,必须赋予那些用户权限.
  我们有以下几种权限:SELECT(读), INSERT(追加), UPDATE(写),DELETE, RULE(规则),REFERENCES(外键), TRIGGER, CREATE,TEMPORARY,EXECUTE, USAGE,和 ALL PRIVILEGES。 有关PostgreSQL所支持的权限的更多信息,请 参阅 PostgreSQL 参考手册 里面的 GRANT 页获取更多详细的信息. 修改或者删除一个对象的权限总是只有该对象的所有者才有. 要赋予权限,必需使用 GRANT 命令. 要赋权限,用GRANT命令.因此,如果 joe 是一个现存用户,而 accounts是一个现存表,那么可以这样赋予更新权限
  GRANT UPDATE ON accounts TO joe;
  执行这条命令的用户必须是表的所有者.要给一个组赋权限,用
  GRANT SELECT ON accounts TO GROUP staff;
  特殊的"用户"名 PUBLIC可以用于 给系统中的每一个用户赋权限.写 ALL 在 权限声明位置上表明赋予所有权限.
  要废除一个权限,用 REVOKE 命令:
  REVOKE ALL ON accounts FROM PUBLIC;
  表所有者的特殊权限(也就是说,做 DROP,GRANT, REVOKE 等等的权限)总是隐含给所有者的,并且不能赋予或者删除. 但是表所有者可以废除他的普通权限,比如给自己做一个只读的表,就象给 别人做一样.

十三、客户端psql的操作

  *查看PostgreSQL的系统表:(摸索/查找中) 
  *终端登录: 
  psql -l[主机名/IP] -d[数据库名] -U[用户名] 
  *连接到另外一个数据库: 
  /c [数据库名] 
  *断开终端: 
  /q 
  ======================================== 
  [基本用户管理]========================== 
  *添加用户: 
  create user [用户名]; 
  *修改用户密码: 
  alter user [用户名] with password [口令]; 
  *删除用户: 
  drop user [用户名]; 
  *查看用户信息: 
  (摸索/查找中) 
  ======================================== 
  [基本数据库操作]======================== 
  *创建数据库: 
  create database [数据库名]; 
  *查看数据库列表: 
  /d 
  *删除数据库: 
  drop database [数据库名]; 
  *修改数据库的所有者: 
  (摸索/查找中) 
  ======================================== 
  [数据库内基本操作]====================== 
  *给予某用户在某数据库创建表的授权: 
  (摸索/查找中) 
  *收回某用户在某数据库创建表的授权: 
  (摸索/查找中) 
  创建表: 
  create table ([字段名1] [类型1] ,[字段名2] [类型2],......<,primary key (字段名m,字段名n,...)>); 
  *查看表名列表: 
  /d 
  *查看某个表的状况: 
  /d [表名] 
  *重命名一个表: 
  alter table [表名A] rename to [表名B]; 
  *修改表的所有者: 
  (摸索/查找中) 
  *删除一个表: 
  drop table [表名]; 
  ======================================== 
  [表内基本操作]========================== 
  *在已有的表里添加字段: 
  alter table [表名] add column [字段名] [类型]; 
  *删除表中的字段: 
  alter table [表名] drop column [字段名]; 
  *重命名一个字段: 
  alter table [表名] rename column [字段名A] to [字段名B]; 
  *给一个字段设置缺省值: 
  alter table [表名] alter column [字段名] set default [新的默认值]; 
  *去除缺省值: 
  alter table [表名] alter column [字段名] drop default; 
  *将已存在的表里某列设置为主码: 
  (摸索/查找中) 
  *将已存在的表里某几列设置为主码: 
  (摸索/查找中) 
  *取消某列的主码资格: 
  (摸索/查找中) 
  在表中插入数据: 
  insert into 表名 ([字段名m],[字段名n],......) values ([列m的值],[列n的值],......); 
  修改表中的某行某列的数据: 
  update [表名] set [目标字段名]=[目标值] where [该行特征]; 
  删除表中某行数据: 
  delete from [表名] where [该行特征]; 
  delete from [表名];--删空整个表 
  ======================================== 
  [备份]================================== 
  备份一个数据库: 
  pg_dump 数据库名 > 备份文件 
  把备份文件导回原数据库或导入新数据库: 
  cat 备份文件 | psql 数据库名 
  最好先把这个数据库的认证改为“trust”。 
  备份一个表: 
  pg_dump -t table1 dbname > bk1.sql 
  ======================================== 
  ADD 
  需要为 psql 程序带入参数:psql -d databasename -U username -W。-d 用来指定数据库,-U 指定用户名,而 -W 要求 psql 提示你输入一个口令。当你成功地运行了 psql 以后,将每个 CREATE TABLE 查询单独地粘贴到 psql 中并按回车键。如果在你的 SQL 语句中有错误,psql 会给出相应提示。通过逐一地加入每一个表,你会得到每一个表的调试信息,这样做起来相当简单。


推荐阅读
  • 本文详细介绍了IBM DB2数据库在大型应用系统中的应用,强调其卓越的可扩展性和多环境支持能力。文章深入分析了DB2在数据利用性、完整性、安全性和恢复性方面的优势,并提供了优化建议以提升其在不同规模应用程序中的表现。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • Valve 发布 Steam Deck 的新版 Windows 驱动程序
    Valve 最新发布了针对 Steam Deck 掌机的 Windows 驱动程序,旨在提升其在 Windows 环境下的兼容性、安全性和性能表现。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • 优化版Windows 10 LTSC 21H2企业版:适用于低内存设备
    此版本为经过优化的Windows 10 LTSC 21H2企业版,特别适合低内存配置的计算机。它基于官方版本进行了精简和性能优化,确保在资源有限的情况下依然能够稳定运行。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
author-avatar
gu油漆装修
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有