标签云
asm恢复 bbed bootstrap$ dul In Memory kcbzib_kcrsds_1 kccpb_sanity_check_2 MySQL恢复 ORA-00312 ORA-00607 ORA-00704 ORA-00742 ORA-01110 ORA-01555 ORA-01578 ORA-01595 ORA-08103 ORA-600 2131 ORA-600 2662 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 Oracle 恢复 ORACLE恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (103)
- 数据库 (1,769)
- DB2 (22)
- MySQL (77)
- Oracle (1,610)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (166)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (69)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (29)
- Oracle备份恢复 (592)
- Oracle安装升级 (97)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (86)
- PostgreSQL (30)
- pdu工具 (6)
- PostgreSQL恢复 (9)
- SQL Server (32)
- SQL Server恢复 (13)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (39)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (22)
-
最近发表
- 2025年的Oracle 8.0.5数据库恢复
- ORA-600 kokiasg1故障分析(obj$中核心字典序列全部被恶意删除)
- ORA-00756 ORA-10567故障数据0丢失恢复
- 数据库文件变成32k故障恢复
- tcp连接过多导致监听TNS-12532 TNS-12560 TNS-00502错误
- 文件系统格式化MySQL数据库恢复
- .sstop勒索加密数据库恢复
- 解决一次硬件恢复之后数据文件0kb的故障恢复case
- Error in invoking target ‘libasmclntsh19.ohso libasmperl19.ohso client_sharedlib’问题处理
- ORA-01171: datafile N going offline due to error advancing checkpoint
- linux环境oracle数据库被文件系统勒索加密为.babyk扩展名溯源
- ORA-600 ksvworkmsgalloc: bad reaper
- ORA-600 krccfl_chunk故障处理
- Oracle Recovery Tools恢复案例总结—202505
- ORA-600 kddummy_blkchk 数据库循环重启
- 记录一次asm disk加入到vg通过恢复直接open库的案例
- CHECKDB 发现了 N 个分配错误和 M 个一致性错误
- 达梦数据库dm.ctl文件异常恢复
- Oracle Recovery Tools修复ORA-00742、ORA-600 ktbair2: illegal inheritance故障
- 可能是 tempdb 空间用尽或某个系统表不一致故障处理
月归档:八月 2018
增加默认值列exp DIRECT=Y导出,导入遭遇ORA-01400
最近的一次数据迁移中使用exp导出遭遇到ORA-01400: cannot insert NULL into 错误,凭着经验对其进行了重现,确定是由于增加默认值的列,使用DIRECT=Y 导出导致该问题
创建测试表
创建一张表,并且增加带默认值而且不为空的列,然后使用exp DIRECT=Y 导出数据
SQL> select * from v$version; BANNER -------------------------------------------------------------------------------- Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production PL/SQL Release 11.2.0.4.0 - Production CORE 11.2.0.4.0 Production TNS for Linux: Version 11.2.0.4.0 - Production NLSRTL Version 11.2.0.4.0 - Production SQL> create table t_xifenfei as select * from dba_objects; Table created. SQL> alter table t_xifenfei add (c_xifenfei varchar2(30) default 'www.xifenfei.com' not null); Table altered. SQL> select c_xifenfei from t_xifenfei where rownum<10; C_XIFENFEI ------------------------------ www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com 9 rows selected. [oracle@bogon ~]$ exp xff/oracle tables=t_xifenfei FEEDBACK=10000 COMPRESS=NO \ > BUFFER=102400000 STATISTICS=none DIRECT=Y recordlength=65535 file=/tmp/t_xifenfei.dmp Export: Release 11.2.0.4.0 - Production on Tue Aug 21 15:56:52 2018 Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved. Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production With the Partitioning, OLAP, Data Mining and Real Application Testing options Export done in US7ASCII character set and AL16UTF16 NCHAR character set server uses ZHS16GBK character set (possible charset conversion) About to export specified tables via Direct Path ... . . exporting table T_XIFENFEI ........ 86421 rows exported Export terminated successfully without warnings.
测试导入数据
导入到另外一个用户下面
[oracle@bogon ~]$ imp xff1/oracle file=/tmp/t_xifenfei.dmp fromuser=xff touser=xff1 Import: Release 11.2.0.4.0 - Production on Tue Aug 21 15:57:53 2018 Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved. Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production With the Partitioning, OLAP, Data Mining and Real Application Testing options Export file created by EXPORT:V11.02.00 via direct path Warning: the objects were exported by XFF, not by you import done in US7ASCII character set and AL16UTF16 NCHAR character set import server uses ZHS16GBK character set (possible charset conversion) . importing XFF's objects into XFF1 . . importing table "T_XIFENFEI" IMP-00019: row rejected due to ORACLE error 1400 IMP-00003: ORACLE error 1400 encountered ORA-01400: cannot insert NULL into ("XFF1"."T_XIFENFEI"."C_XIFENFEI") Column : SYS Column : ICOL$ Column : Column : 20 Column : 2 Column : TABLE Column : 24-AUG-2013:11:37:35 Column : 24-AUG-2013:11:47:37 Column : 2013-08-24:11:37:35 Column : VALID Column : N Column : N Column : N Column : 1 Column : Column : IMP-00019: row rejected due to ORACLE error 1400 IMP-00003: ORACLE error 1400 encountered ORA-01400: cannot insert NULL into ("XFF1"."T_XIFENFEI"."C_XIFENFEI")
这里可以看到,故障已经重现ORA-01400: cannot insert NULL into,无法将空值插入到刚刚新加的默认值的列中
使用常规导出
[oracle@bogon ~]$ exp xff/oracle tables=t_xifenfei FEEDBACK=10000 COMPRESS=NO BUFFER=102400000 STATISTICS=none file=/tmp/t_xifenfei1.dmp Export: Release 11.2.0.4.0 - Production on Tue Aug 21 16:00:50 2018 Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved. Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production With the Partitioning, OLAP, Data Mining and Real Application Testing options Export done in US7ASCII character set and AL16UTF16 NCHAR character set server uses ZHS16GBK character set (possible charset conversion) About to export specified tables via Conventional Path ... . . exporting table T_XIFENFEI ........ 86421 rows exported Export terminated successfully without warnings.
导入数据
[oracle@bogon ~]$ imp xff1/oracle file=/tmp/t_xifenfei1.dmp fromuser=xff touser=xff1 Import: Release 11.2.0.4.0 - Production on Tue Aug 21 16:04:47 2018 Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved. Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production With the Partitioning, OLAP, Data Mining and Real Application Testing options Export file created by EXPORT:V11.02.00 via conventional path Warning: the objects were exported by XFF, not by you import done in US7ASCII character set and AL16UTF16 NCHAR character set import server uses ZHS16GBK character set (possible charset conversion) . importing XFF's objects into XFF1 . . importing table "T_XIFENFEI" 86421 rows imported Import terminated successfully without warnings. [oracle@bogon ~]$ [oracle@bogon ~]$ sqlplus xff1/oracle SQL*Plus: Release 11.2.0.4.0 Production on Tue Aug 21 16:10:16 2018 Copyright (c) 1982, 2013, Oracle. All rights reserved. Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production With the Partitioning, OLAP, Data Mining and Real Application Testing options SQL> select c_xifenfei from t_xifenfei where rownum<10; C_XIFENFEI ------------------------------ www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com www.xifenfei.com 9 rows selected.
通过测试证明,对于11g新特性增加默认值,而且非为空的列,如果使用exp常规方法导入,再导出没有任何问题,如果使用DIRECT=Y特性,将导致导入失败(ORA-01400).这是由于11g的快速增加列和默认值且不为空的新特性导致的(直接修改字典,并没有真正的去修改数据底层存储).
查询mos发现匹配bug: Bug 13961541 : EXP WITH DIRECT=Y CAN NOT HANDLE ADD COLUMN DEFAULT NOT NULL FEATURE IN 11G
数据库升级报ORA-07445 joxchrcnv
朋友在aix平台数据库10.2.0.3升级到10.2.0.5过程中,运行catupgrd.sql脚本,遭遇ORA-07445 joxchrcnv错误
--catupgrd.sql前台报错 Table altered. Table altered. BEGIN * ERROR at line 1: ORA-03113: end-of-file on communication channel ERROR: ORA-03114: not connected to ORACLE --trace文件报错 *** 2018-08-09 14:41:29.742 ksedmp: internal or fatal error ORA-07445: exception encountered: core dump [joxchrcnv+00a8] [SIGSEGV] [Address not mapped to object] [0x500000040] [] [] Current SQL statement for this session: REVOKE all ON SYS.hs_bulk_seq FROM PUBLIC ----- PL/SQL Call Stack ----- object line object handle number name 7000000e9942b80 2 anonymous block ----- Call Stack Trace ----- calling call entry argument values in hex location type point (? means dubious value) -------------------- -------- -------------------- ---------------------------- ksedst+001c bl ksedst1 000000000 ? 000000001 ? ksedmp+0290 bl ksedst 104C1FC50 ? ssexhd+03e0 bl ksedmp 300001D15 ? 0000441C ? 00000000 joxcdtu+0088 bl joxchrcnv 11019B760 ? 7000000E2CEBC70 ? FFFFFFFFFFE82A0 ? 7000000E37EFDC8 ? 000000000 ? 000000000 ? 000000002 ? 7000000E1A8B250 ? joxcnas+007c bl joxcdtu 110008BE0 ? 7000000E5FD3670 ? FFFFFFFFFFE71C0 ? 4642408300000004 ? 104BAF6F0 ? 7000000E6BE6B48 ? joxsnm_+0020 bl joxcnas 7000000E5FD4E30 ? 000000001 ? 000000000 ? 7000000E2CEB8D0 ? 7000000E991C6E0 ? 11019B760 ? FFFFFFFFFFE82E0 ? joxsnm+0010 bl 03754C58 kkdlJavasnmAltName+ bl 01FC3B1C 0048 qcdlgbo+0908 bl _ptrgl qcdlgob+0560 bl qcdlgbo FFFFFFFFFFEF8C0 ? 11019B760 ? 11057B380 ? 7000000E2CEC960 ? 000000000 ? 104DA95B0 ? 700000010017FA0 ? 400000000 ? qcsfgob+0220 bl qcdlgob FFFFFFFFFFE8B20 ? 1058251F8 ? FFFFFFFFFFE9000 ? 000000001 ? 00000000B ? 000000000 ? 0000000C7 ? qcsprfro+04a4 bl qcsfgob 1104300C0 ? 000000000 ? 1100C1848 ? 11019B760 ? qcsprfro_tree+0454 bl qcsprfro 000000000 ? 000000000 ? FFFFFFFFFFE8DE8 ? 000000000 ? qcsprfro_tree+0258 bl qcsprfro_tree 000000001 ? 000000000 ? FFFFFFFFFFE8DA0 ? 11057B380 ? 7000000E1ACA8F8 ? 000000000 ? qcspafq+0068 bl qcsprfro_tree 11058DEA0 ? FFFFFFFFFFE9040 ? FFFFFFFFFFE8E50 ? 4822208200000010 ? 10277AD14 ? 110118F58 ? qcspqbDescendents+0 bl qcspafq 000000000 ? 110008BE0 ? 3a0 FFFFFFFFFFEFF70 ? qcspqb+00ac bl qcspqbDescendents 10008CC20 ? 000000000 ? 7000000E2CEC638 ? kkmdrv+003c bl qcspqb FFFFFFFFFFE9080 ? 88832081E9999F10 ? FFFFFFFFFFE9080 ? opiSem+1450 bl kkmdrv 000000000 ? 000001068 ? 11019E058 ? 11058DA68 ? opiprs+01ac bl opiSem FFFFFFFFFFEFF70 ? 110502A18 ? 00000002A ? 000000001 ? kksParseChildCursor bl opiprs 10008CC20 ? 000000000 ? +0640 104C29C50 ? 07FFFFFF8 ? 000000FE8 ? 000000001 ? rpiswu2+0368 bl _ptrgl kksLoadChild+20cc bl rpiswu2 7000000EAA86FE0 ? 000000000 ? 000000000 ? 000000000 ? 000000000 ? 000000000 ? 000000000 ? 000000000 ? kxsGetRuntimeLock+0 bl kksLoadChild 11019B760 ? 7000000E9AE5520 ? 89c 7000000E38176D8 ? kksfbc+2830 bl kxsGetRuntimeLock 11019B760 ? 11057B380 ? FFFFFFFFFFF18D8 ? 000000000 ? 000000000 ? kkspsc0+1570 bl kksfbc 11057B380 ? 3FFFF2858 ? 108E381B6C0 ? 110502A18 ? 00000002A ? 000000000 ? 000000000 ? 000000000 ? kksParseCursor+00d4 bl kkspsc0 110431A68 ? 110502A18 ? 00000002A ? 310231CF0 ? 610431A68 ? 222000000000000A ? 000000000 ? opiosq0+0b40 bl 01FC69A4 opipls+0638 bl opiosq0 3EA6B0DF8 ? 110008BE0 ? 110118F58 ? 22200000EAADBE88 ? 000000000 ? opiodr+0b2c bl _ptrgl rpidrus+01dc bl opiodr 6600000000 ? 6E2D017E0 ? FFFFFFFFFFF6C80 ? AFFFF5CD0 ? skgmstack+00c8 bl _ptrgl rpidru+0088 bl skgmstack 7000000E37EFB20 ? FFFFFFFFFFF5C30 ? FFFFFFFFFFF6080 ? 26214040000010F0 ? 100417334 ? rpiswu2+0368 bl _ptrgl rpidrv+097c bl rpiswu2 7000000EAA86FE0 ? 11019B760 ? FFFFFFFFFFF6400 ? 000000004 ? 7000000E37EFB50 ? 0E9942BE0 ? 7000000E9942BF0 ? 000000000 ? psddr0+02dc bl 01FC6E18 psdnal+01d0 bl psddr0 A00000000 ? 6600000000 ? FFFFFFFFFFF6C80 ? 3100000000 ? pevm_EXIM+0120 bl _ptrgl pfrinstr_EXIM+0034 bl pevm_EXIM 1105BD288 ? 000000000 ? pfrrun_no_tool+005c bl _ptrgl pfrrun+1064 bl pfrrun_no_tool 5800000000 ? 110231CF0 ? FFFFFFFFFFF6FA0 ? plsql_run+06e8 bl pfrrun 110449078 ? peicnt+0244 bl plsql_run 110449078 ? 1000000000418 ? 000000000 ? kkxexe+0250 bl peicnt FFFFFFFFFFF82D8 ? 110449078 ? opiexe+3024 bl kkxexe 1104DAEC8 ? kpoal8+0ef0 bl opiexe FFFFFFFFFFFB954 ? 1103AA798 ? FFFFFFFFFFF9AF0 ? opiodr+0b2c bl _ptrgl ttcpip+1020 bl _ptrgl opitsk+117c bl 01FC6888 opiino+09d0 bl opitsk 1EFFFFD920 ? 000000000 ? opiodr+0b2c bl _ptrgl opidrv+04a4 bl opiodr 3C102A7758 ? 404C72B18 ? FFFFFFFFFFFF8E0 ? 0102A7750 ? sou2o+0090 bl opidrv 3C02A288DC ? 400000010 ? FFFFFFFFFFFF8E0 ? opimai_real+01bc bl 01FC30F4 main+0098 bl opimai_real 000000000 ? 000000000 ? __start+0098 bl main 000000000 ? 000000000 ? --------------------- Binary Stack Dump ---------------------
根据Catupgrd.sql Fails with ORA-3113/ORA-7445 During Grant Select On ALL_JOBS to Public with Grant Option (Doc ID 419309.1)文档,处理建议
1. Make sure LD_LIBRARY_PATH or LIBPATH is set correctly: AIX ==== export LIBPATH=$ORACLE_HOME/lib:$LIBPATH HP-UX ===== export LD_LIBRARY_PATH=$ORACLE_HOME/lib export SHLIB_PATH=$ORACLE_HOME/lib32 HP Tru-64 ======== export LD_LIBRARY_PATH=$ORACLE_HOME/lib SUN Sparc Solaris-64Bit ================== export LD_LIBRARY_PATH_64=$ORACLE_HOME/lib export LD_LIBRARY_PATH=$ORACLE_HOME/lib32 SUN Sparc Solaris-32Bit ================== export LD_LIBRARY_PATH=$ORACLE_HOME/lib Linux ===== export LD_LIBRARY_PATH=$ORACLE_HOME/lib 2. Make sure ORA_NLS parameter is set correctly. See the following notes for assistance: Note 77442.1 (ORA_NLS32, ORA_NLS33, ORA_NLS10) Environment Variables explained. 3. Make sure Listener is also started with the correct environment variables if you were doing remote connection from client through sqlnet rather than local connection to database. 4. Shutdown the database and rerun the upgrade: SQL> SHUTDOWN IMMEDIATE SQL> STARTUP UPGRADE SQL> SPOOL patch.log SQL> @?/rdbms/admin/catupgrd.sql 5. If the above failed then it might be due to the libjox *.a file is not replaced during upgrade or install.
由于软件升级不正常,导致数据库升级出现该问题,在升级软件过程中,一定检查升级软件和升级结果
PostgreSQL常见字符串操作函数
转载:pmars blog中关于pg字符串相关函数
函数:string || string 说明:String concatenation 字符串连接操作 例子:select 'Post' || 'greSQL'; = PostgreSQL 函数:string || non-string or non-string || string 说明:String concatenation with one non-string input 字符串与非字符串类型进行连接操作 例子:select 'Value: ' || 42; = Value: 42 函数:bit_length(string) 说明:Number of bits in string 计算字符串的位数 例子:select bit_length('pmars') = 40 函数:char_length(string) or character_length(string) 说明:Number of characters in string 计算字符串中字符个数 例子:select char_length('pmars'); = 5 函数:lower(string) 说明:Convert string to lower case 转换字符串为小写 例子:select lower('PmArS'); = "pmars" 函数:octet_length(string) 说明:Number of bytes in string 计算字符串的字节数 例子:select octet_length('我是pmars'); = 11 select octet_length('我'); = 3 函数:overlay(string placing string from int [for int]) 说明:Replace substring 替换字符串中任意长度的子字串为新字符串 例子:select overlay('I am pmars' placing 'ming' from 6 for 5); = "I am ming" 函数:position(substring in string) 说明:Location of specified substring 子串在一字符串中的位置 例子:select position('ma' in 'pmars'); = 2 函数:substring(string [from int] [for int]) 说明:Extract substring 截取任意长度的子字符串 例子:select substring('topmars' from 3 for 3); = "pma" 函数:substring(string from pattern) 说明:Extract substring matching POSIX regular expression. See Section 9.7 for more information on pattern matching. 利用正则表达式对一字符串进行任意长度的字串的截取 例子:select substring('topmars' from 'p.*$'); = "pmars" 函数:substring(string from pattern for escape) 说明:Extract substring matching SQL regular expression. See Section 9.7 for more information on pattern matching. 利于正则表达式对某类字符进行删除,以得到子字符串 例子:select substring('Thomas' from '%#"o_a#"_' for '#'); = "oma" 函数:trim([leading | trailing | both] [characters] from string) 说明:Remove the longest string containing only the characters (a space by default) from the start/end/both ends of the string 去除尽可能长开始,结束或者两边的某类字符,默认为去除空白字符,当然可以自己指定,可同时指定多个要删除的字符串 例子:select trim(leading 'p' from 'pmars'); = "mars" 函数:upper(string) 说明:Convert string to uppercase 将字符串转换为大写 例子:select upper('pmars'); = "PMARS" 函数:ascii(string) 说明:ASCII code of the first character of the argument. For UTF8 returns the Unicode code point of the character. For other multibyte encodings. the argument must be a strictly ASCII character. 得到某一个字符的Assii值 例子:select ascii('pmars'); = select ascii('p'); = 112 函数:btrim(string text [, characters text]) 说明:Remove the longest string consisting only of characters in characters (a space by default) from the start and end of string 去除字符串两边的所有指定的字符,可同时指定多个字符 例子:select btrim('pmars','prs'); = "ma" 函数:chr(int) 说明:Character with the given code. For UTF8 the argument is treated as a Unicode code point. For other multibyte encodings the argument must designate a strictly ASCII character. The NULL (0) character is not allowed because text data types cannot store such bytes. 得到某ACSII值对应的字符 例子:select chr(65); = A 函数:convert(string bytea, src_encoding name, dest_encoding name) 说明:Convert string to dest_encoding. The original encoding is specified by src_encoding. The string must be valid in this encoding. Conversions can be defined by CREATE CONVERSION. Also there are some predefined conversions. See Table 9-7 for available conversions. 转换字符串编码,指定源编码与目标编码 例子:select convert('我是pmars_in_utf8', 'UTF8', 'GBK'); = "\316\322\312\307pmars_in_utf8" 函数:convert_from(string bytea, src_encoding name) 说明:Convert string to the database encoding. The original encoding is specified by src_encoding. The string must be valid in this encoding. 转换字符串编码,自己要指定源编码,目标编码默认为数据库指定编码, 例子:select convert_from('\316\322\312\307pmars','GBK'); = "我是pmars" 函数:convert_to(string text, dest_encoding name) 说明:Convert string to dest_encoding.转换字符串编码,源编码默认为数据库指定编码,自己要指定目标编码, 例子:select convert_to('我是pmars_in_utf8','GBK'); = "\316\322\312\307pmars_in_utf8" 函数:decode(string text, type text) 说明:Decode binary data from string previously encoded with encode. Parameter type is same as in encode. 对字符串按指定的类型进行解码 例子:select decode('MTIzAAE=', 'base64'); = "123\000\001" 函数:encode(data bytea, type text) 说明:Encode binary data to different representation. Supported types are: base64, hex, escape. Escape merely outputs null bytes as \000 and doubles backslashes. 与decode相反,对字符串按指定类型进行编码 例子:select encode('123\000\001','base64'); = "MTIzAAE=" 函数:initcap(string) 说明:Convert the first letter of each word to uppercase and the rest to lowercase. Words are sequences of alphanumeric characters separated by non-alphanumeric characters. 将字符串所有的单词进行格式化,首字母大写,其它为小写 例子:select initcap('I AM PMARs'); = "I Am Pmars" 函数:length(string) 说明:Number of characters in string 讲算字符串长度 例子:select length('我是pmars'); = 7 函数:length(stringbytea, encoding name ) 说明:Number of characters in string in the given encoding. The string must be valid in this encoding. 计算字符串长度,指定字符串使用的编码 例子:select length('我是pmars','GBK'); = 8 函数:lpad(string text, length int [, fill text]) 说明:Fill up the string to length length by prepending the characters fill (a space by default). If the string is already longer than length then it is truncated (on the right). 对字符串左边进行某类字符自动填充,即不足某一长度,则在左边自动补上指定的字符串,直至达到指定长度,可同时指定多个自动填充的字符 例子:select lpad('pmars', 10, 'to'); = "tototpmars" 函数:ltrim(string text [, characters text]) 说明:Remove the longest string containing only characters from characters (a space by default) from the start of string 删除字符串左边某一些的字符,可以时指定多个要删除的字符 例子:select ltrim('pmars','amp'); = "rs" 函数:md5(string) 说明:Calculates the MD5 hash of string, returning the result in hexadecimal 将字符串进行md5编码 例子:select md5('pmars'); = "1018ceb949f1472f7252f7da1f5eff42" 函数:pg_client_encoding() 说明:Current client encoding name 得到pg客户端编码 例子:select pg_client_encoding(); = "UTF8" 函数:quote_ident(string text) 说明:Return the given string suitably quoted to be used as an identifier in an SQL statement string. Quotes are added only if necessary (i.e., if the string contains non-identifier characters or would be case-folded). Embedded quotes are properly doubled. 对某一字符串加上两引号 例子:quote_ident('Foo bar') = "Foo bar" 函数:quote_literal(string text) 说明:Return the given string suitably quoted to be used as a string literal in an SQL statement string. Embedded single-quotes and backslashes are properly doubled. 对字符串里两边加上单引号,如果字符串里面出现sql编码的单个单引号,则会被表达成两个单引号 例子:quote_literal('O\'Reilly') = 'O''Reilly' 函数:quote_literal(value anyelement) 说明:Coerce the given value to text and then quote it as a literal. Embedded single-quotes and backslashes are properly doubled. 将一数值转换为字符串,并为其两边加上单引号,如果数值中间出现了单引号,也会被表示成两个单引号 例子:quote_literal(42.5) = '42.5' 函数:regexp_matches(string text, pattern text [, flags text]) 说明:Return all captured substrings resulting from matching a POSIX regular expression against the string. See Section 9.7.3 for more information. 对字符串按正则表达式进行匹配,如果存在则会在结果数组中表示出来 例子:regexp_matches('foobarbequebaz', '(bar)(beque)') = {bar,beque} 函数:regexp_replace(string text, pattern text, replacement text [, flags text]) 说明:Replace substring(s) matching a POSIX regular expression. See Section 9.7.3 for more information. 利用正则表达式对字符串进行替换 例子:regexp_replace('Thomas', '.[mN]a.', 'M') = ThM 函数:regexp_split_to_array(string text, pattern text [, flags text ]) 说明:Split string using a POSIX regular expression as the delimiter. See Section 9.7.3 for more information. 利用正则表达式将字符串分割成数组 例子:regexp_split_to_array('hello world', E'\\s+') = {hello,world} 函数:regexp_split_to_table(string text, pattern text [, flags text]) 说明:Split string using a POSIX regular expression as the delimiter. See Section 9.7.3 for more information. 利用正则表达式将字符串分割成表格 例子:regexp_split_to_table('hello world', E'\\s+') = hello world (2 rows) 函数:repeat(string text, number int) 说明:Repeat string the specified number of times 重复字符串一指定次数 例子:repeat('Pg', 4) = PgPgPgPg 函数:replace(string text, from text, to text) 说明:Replace all occurrences in string of substring from with substring to 将字符的某一子串替换成另一子串 例子:('abcdefabcdef', 'cd', 'XX') = abXXefabXXef 函数:rpad(string text, length int [, fill text]) 说明:Fill up the string to length length by appending the characters fill (a space by default). If the string is already longer than length then it is truncated. 对字符串进行填充,填充内容为指定的字符串 例子:rpad('hi', 5, 'xy') = hixyx 函数:rtrim(string text [, characters text]) 说明:Remove the longest string containing only characters from characters (a space by default) from the end of string 去除字符串右边指定的字符 例子:rtrim('trimxxxx', 'x') = trim 函数:split_part(string text, delimiter text, field int) 说明:Split string on delimiter and return the given field (counting from one) 对字符串按指定子串进行分割,并返回指定的数值位置的值 例子:split_part('abc~@~def~@~ghi', '~@~', 2) = def 函数:strpos(string, substring) 说明:Location of specified substring (same as position(substring in string), but note the reversed argument order) 指定字符串在目标字符串的位置 例子:strpos('high', 'ig') = 2 函数:substr(string, from [, count]) 说明:Extract substring (same as substring(string from from for count)) 截取子串 例子:substr('alphabet', 3, 2) = ph 函数:to_ascii(string text [, encoding text]) 说明:Convert string to ASCII from another encoding (only supports conversion from LATIN1, LATIN2, LATIN9, and WIN1250 encodings) 将字符串转换成ascii编码字符串 例子:to_ascii('Karel') = Karel 函数:to_hex(number int or bigint) 说明:Convert number to its equivalent hexadecimal representation 对数值进行十六进制编码 例子:to_hex(2147483647) = 7fffffff 函数:translate(string text, from text, to text) 说明:Any character in string that matches a character in the from set is replaced by the corresponding character in the to set 将字符串中某些匹配的字符替换成指定字符串,目标字符与源字符都可以同时指定多个 例子:translate('12345', '14', 'ax') = a23x5
转载:https://www.cnblogs.com/pmars/archive/2013/02/17/2914046.html
发表在 PostgreSQL
评论关闭