重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
与Oracle中类似,%TYPE是用来获取一个已定义变量的类型的。这样可以方便的定义出于已有变量或字段同类型的变量。例如:
创新互联专注于宜川网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供宜川营销型网站建设,宜川网站制作、宜川网页设计、宜川网站官网定制、小程序开发服务,打造宜川网络公司原创品牌,更为您提供宜川网站排名全网营销落地服务。
do language plpgsql $$
declare v1 character varying(100); -- 定义变量v1类型为变长字串
declare v2 v1%type; -- 定义变量v2与v1同类型,即变长字串
begin
v2 := 'Hello World!'; -- 给v2变量赋值
raise notice '%', v2; -- 显示出v2的内容
end $$;
右击"我的电脑"--"高级"选项卡--"环境变量",在环境变量的弹出窗口的下面,是系统环境变量,针对登陆到这个系统的所有用户,上面则是用户环境变量,针对当前用户有效,看你个人需求,我一般设置的都是系统环境变量。
在"系统变量"列表中,选择变量名为Path的项,点击"编辑",在编辑窗口的"变量值"输入项的最前面输入你的路径,记得以分号结束,点"确定"--"确定"--"确定",就可以完成环境变量设置了
要想打开自动字符集转换功能,你必须告诉 PostgreSQL 你想在客户端使用的字符集(编码)。你可以用好几种方法实现这个目的。
用 psql 里的 /encoding 命令。 /encoding 允许你动态修改客户端编码。 比如,把编码改变为 SJIS,键入:
/encoding SJIS
使用 libpq 函数。 /encoding 在做此用途的时候实际上是调用 PQsetClientEncoding()。
int PQsetClientEncoding(PGconn *conn, const char *encoding);
这里 conn 与后端的联接,而 encoding 是你想用的编码。如果编码设置成功它返回 0,否则返回 -1。本次联接的当前编码可以用下面函数显示:
int PQclientEncoding(const PGconn *conn);
请注意它只返回编码 ID,而不是象 EUC_JP 这样的编码符号字串。 要把编码 ID 转换为编码符号,你可以用:
char *pg_encoding_to_char(int encoding_id);
使用 SET client_encoding TO。 可以用 SQL 命令设置客户端编码:
SET CLIENT_ENCODING TO 'value';
你还可以把 SQL 语法里的 SET NAMES用于这个目的:
SET NAMES 'value';
查询当前客户端编码:
SHOW client_encoding;
返回缺省编码:
RESET client_encoding;
使用 PGCLIENTENCODING。 如果在客户端的环境里定义了 PGCLIENTENCODING 环境变量, 那么在与服务器进行联接时将自动选择客户端编码。 (这个编码随后可以用上面谈到的任何其它方法覆盖。)
使用client_encoding配置变量。 如果在 postgresql.conf 里设置了 client_encoding 变量, 那么在与服务器建立了联接之后,这个客户端编码将自动选定。(这个设置随后可以被上面提到 的其他方法覆盖。)
假如无法进行特定的字符转换 — 比如, 你选的服务器编码是EUC_JP, 客户端是LATIN1,那么有些日文字符不能转换成LATIN1。这时, 不能用LATIN1字符集表示的字母将被转换成圆括弧包围的十六进制,像,(826C) 这样。
如果客户端字符集定义成了 SQL_ASCII,那么编码转换会被关闭, 不管服务器的字符集是什么都一样。和服务器一样,除非你的工作环境全部是 ASCII 数据, 否则使用 SQL_ASCII 是不明智的。
PostgreSQL安装:一、windows下安装过程安装介质:postgresql-9.1.3-1-windows.exe(46M),安装过程非常简单,过程如下:1、开始安装:2、选择程序安装目录:注:安装PostgreSQL的分区最好是NTFS格式的。PostgreSQL首要任务是要保证数据的完整性,而FAT和FAT32文件系统不能提供这样的可靠性保障,而且FAT文件系统缺乏安全性保障,无法保证原始数据在未经授权的情况下被更改。此外,PostgreSQL所使用的"多分点"功能完成表空间的这一特征在FAT文件系统下无法实现。然而,在某些系统中,只有一种FAT分区,这种情况下,可以正常安装PostgreSQL,但不要进行数据库的初始化工作。安装完成后,在FAT分区上手动执行initdb.exe程序即可,但不能保证其安全性和可靠性,并且建立表空间也会失败。3、选择数据存放目录:4、输入数据库超级用户和创建的OS用户的密码注:数据库超级用户是一个非管理员账户,这是为了减少黑客利用在PostgreSQL发现的缺陷对系统造成损害,因此需要对数据库超级用户设置密码,如下图所示,安装程序自动建立的服务用户的用户名默认为postgres。5、设置服务监听端口,默认为54326、选择运行时语言环境注:选择数据库存储区域的运行时语言环境(字符编码格式)。在选择语言环境时,若选择"defaultlocale"会导致安装不正确;同时,PostgreSQL不支持GBK和GB18030作为字符集,如果选择其它四个中文字符集:中文繁体香港(Chinese[Traditional],HongKongS.A.R.)、中文简体新加坡(Chinese[Simplified],Singapore)、中文繁体台湾(Chinese[Traditional],Taiwan)和中文繁体澳门(Chinese[Traditional],MarcoS.A.R.),会导致查询结果和排序效果不正确。建议选择"C",即不使用区域。----我选择了defaultlocalt,安装正确;建议选择defaultlocalt。7、安装过程(2分钟)8、安装完成安装完成后,从开始文件夹可以看到:在安装目录可以看到:其中:data存放数据文件、日志文件、控制文件、配置文件等。uninstall-postgresql.exe用于卸载已安装的数据库管理系统。pg_env.bat里配置了数据库的几个环境变量,内容如下:二、pgAdmin(大象)对于每种数据库管理系统,都有相当多的设计与管理工具(可视化界面管理工具),有的是数据库厂商自己提供的(一般都至少有一个),有的是第三方公司开发的,你甚至可以自己写一个简单易用的管理工具。例如Oracle的OracleSQLDeveloper(自己开发的)、PLSQLDeveloper(第三方公司开发的)、SQLServerManagementStudio(自己开发的)、base目录。在PostgreSQL(pg_catalog)下可以看到postgers数据库的一些数据字典和数据字典视图。新建一个服务器连接,连接远程linux服务器上的PostgreSQL数据库(假设已有远程linux上已安装好PostgreSQL数据库管理系统):得到数据库属性如下图所示:图中可以看出,该远程数据库管理系统上建有两个数据库:postgres、cpost;四个表空间:pg_default、pg_global、pis_data、pis_index。三、pgsql对于每种数据库管理系统,都会提供一个命令行管理接口,例如Oracle的sqlplus,SQLServer的isql和osql等。凡是用图形管理界面可以实现的功能原则上都可以通过命令行界面命令实现。两者各有优缺点,使用场合不同。在windows下当然常用图形管理界面,因为在图像管理界面中往往都嵌有命令行工具,而在unix和linux下,当然就常用命令行工具了,除了我们在类unix下主要使用字符界面的原因外,还因为大部分情况下我们只能通过telnet或ssh工具远程连接服务器进行操作,此时也只能使用命令行了。从开始目录打开SQLshell(pgsql),该可执行程序为E:\PostgreSQL\bin\psql.exe。输入密码得到如下图界面:也可以在修改了系统环境变量Path之后(增加PostgreSQL\bin目录),从命令行直接启动pgsql。至此,PostgreSQL在Windows下安装完毕。
postgresql.conf是PostgreSQL的配置文件。其基本格式为: 一行就是一个配置变量的设定,采用"变量名 = 变量值"的赋值格式。
postgresql.conf一般位于postgresql的数据目录中,它是在postgresql数据集创建时自动创建出来的。可以通过修改postgresql.conf来修改PostgreSQL的配置变量值。
用raise notice函数来打印变量的值。示例SQL: create or replace function ads.showText(p_text character varying)returns voidas $$begin raise notice 'Parameter is: %', p_text;end;调用SQL: select ads.showText('Hello World');