【PostgreSQL-9.6.3】函数(2)--字符型函数
在上一篇博文中我们交流了数值型函数,这篇我们将讨论PostgreSQL中的字符型函数。
1. reverse(string)
reverse函数可以将string字符串的字母显示顺序颠倒。
test=# select reverse ('world');
reverse
---------
dlrow
(1 row)
test=#
2. position(str1 in str)
position函数用来返回子字符串str1在str中的开始位置。
test=# select position ('ball' in 'basketball');
position
----------
7
(1 row)
test=#
3. replace (s,s1,s2)
replace函数返回字符串s2替代字符串s中所有的字符串s1后的结果。
test=# select replace ('aello','a','h');
replace
---------
hello
(1 row)
test=#
4. repeat(s,n)
repeat用来返回字符串s重复n次的值。当n<=0、s或n为null,都会返回空值。
test=# select repeat('world',2) as col1,repeat('world',-1) as col2,repeat(null,2) as col3,repeat('world',null);
col1 | col2 | col3 | repeat
------------+------+------+--------
worldworld | | |
(1 row)
test=#
5. ltrim(str)、rtrim(str)和trim(str)
ltrim返回删除左边空格后的字符串str;
rtrim返回删除右边空格后的字符串str;
trim返回删除左右两边空格后的字符串str。
test=# select '( world )',concat('(',ltrim(' world '),')') as col1,concat('(',rtrim(' world '),')') as col2,concat('(',trim(' world '),')') as col3;
?column? | col1 | col2 | col3
-----------+----------+----------+---------
( world ) | (world ) | ( world) | (world)
(1 row)
test=#
6. trim (s1 from s)
trim (s1 from s)删除字符串s中两端的s1,当s1缺省时,默认删除空格。在字符串内部出现的s1不会被删除。
test=# select trim ('abc' from 'abcpostabcgresqlabc');
btrim
---------------
postabcgresql
(1 row)
test=#
7. lpad(s1,len,s2)和rpad(s1,len,s2)
lpad和rpad函数,用字符串s2在s1的左/右填充,使s1到达len个字符长度,最终返回填充后的s1。假如s1大于len长度,则返回值被缩短至len长度。
test=# select 'world',lpad('world',10,'x') as col1,lpad('world',3,'x') as col2,rpad('world',10,'x') as col3,rpad('world',3,'x') as col4;
?column? | col1 | col2 | col3 | col4
----------+------------+------+------------+------
world | xxxxxworld | wor | worldxxxxx | wor
(1 row)
test=#
8. left(s,n)和right(s,n)
left(s,n)和right(s,n)返回字符串s最左/右边开始的n的字符。
test=# select left('postgresql',4) as col1,right('postgresql',3) as col2;
col1 | col2
------+------
post | sql
(1 row)
test=#
9. concat(s1,s2,s3...)和concat_ws(x,s1,s2,s3...)
concat(s1,s2,s3...)表示将括号内的字符串连接在一起,不能指定分隔符;
concat_ws(x,s1,s2,s3...)功能和concat一样,但可以指定x为分隔符;
括号内的字符串为null,则在连接时自动忽略;只要有一个参数是二进制字符串,那么结果将会是二进制字符串格式。
test=# select concat('I','Love','China') as col1,concat_ws('-','I','Love','China') as col2;
col1 | col2
------------+--------------
ILoveChina | I-Love-China
(1 row)
test=#
10. char_length(str)和length(str)
char_length返回str字符串的字符个数,length返回字符串str的字节个数。在我们经常使用的utf8字符集中,一个数字或者字符占一个字节,一个汉字占三个字节。
test=# select char_length('world') as col1,length('world') as col2;
col1 | col2
------+------
5 | 5
(1 row)
test=#
【PostgreSQL-9.6.3】函数(2)--字符型函数的更多相关文章
- oracle 10g函数大全--字符型函数
ASCII(x1) [功能]:返回字符表达式最左端字符的ASCII 码值. [参数]:x1,字符表达式 [返回]:数值型 [示例] SQL> select ascii('A') A,ascii( ...
- Oracle 函数-字符型函数
1.字符型函数 函数 说明 案例 结果 ASCII(X) 求字符X的ASCII码 select ASCII('A') FROM DUAL; 65 CHR(X) 求ASCII码对应的字符 select ...
- PostgreSQL学习手册(五) 函数和操作符
PostgreSQL学习手册(五) 函数和操作符 一.逻辑操作符: 常用的逻辑操作符有:AND.OR和NOT.其语义与其它编程语言中的逻辑操作符完全相同. 二.比较操作符: 下面是Post ...
- Java语言程序设计(基础篇) 第四章 数学函数、字符和字符串
第四章 数学函数.字符和字符串 4.2 常用数学函数 方法分三类:三角函数方法(trigonometric method).指数函数方法(exponent method)和服务方法(service m ...
- PostgreSQL的时间/日期函数使用
PostgreSQL的常用时间函数使用整理如下: 一.获取系统时间函数 1.1 获取当前完整时间 select now(); david=# select now(); now ----------- ...
- PHP iconv()函数转字符编码的问题(转)
PHP iconv()函数转字符编码的问题(转) 载自:http://www.nowamagic.net/php/php_FunctionIconv.php 在php函数库有一个函数:iconv(), ...
- C++学习46 getline()函数读入一行字符 一些与输入有关的istream类成员函数
getline函数的作用是从输入流中读取一行字符,其用法与带3个参数的get函数类似.即 cin.getline(字符数组(或字符指针), 字符个数n, 终止标志字符) [例13.7] 用get ...
- [转] PostgreSQL的时间/日期函数使用
PS:http://blog.csdn.net/love_rongrong/article/details/6712883 字符串模糊比较 日期类型的模糊查询是不能直接进行的,要先转换成字符串然后再查 ...
- oracle函数大全-字符处理函
字符函数——返回字符值 这些函数全都接收的是字符族类型的参数(CHR 除外)并且返回字符值.除了特别说明的之外,这些函数大部分返回VARCHAR2类型的数值.字符函数的返回类型所受的限制和基本数据库类 ...
随机推荐
- elisp 编程 if 特殊表
elisp中的 if 特殊表与其他语言中的 if 语句逻辑上并无二致,关键在于如何使用. (if (> 4 3) (message "4 is greater than 3" ...
- Django——1 环境搭建
Django 什么是Django 使用前的准备工作 新建项目 开启服务器 新建APP 简单实战 什么是Django框架 http服务器:用来接受用户请求,并将请求转发给web应用框架进行处理.Web应 ...
- 51nod挑的部分5级题
最近心情不好所以写代码来获得快落 4级题有点难做?然后就开始挑简单的5级题开始写 然后准备记录一些自己没有做出来 参考讨论区或者博客才做出来的题目 51nod_1189 阶乘分数 这个题参考了讨论区 ...
- poj 1273最大流dinic算法模板
#include<stdio.h> #include<string.h> #define N 300 #define inf 0x7fffffff #include<qu ...
- Spring Boot访问mysql(JPA方式)最简单配置
0.先推荐一个工具--lombok,pom文件如下: <dependency> <groupId>org.projectlombok</groupId> <a ...
- readl()和writel()
writel() 往内存映射的 I/O 空间上写数据,wirtel() I/O 上写入 32 位数据 (4字节). 原型: 引用 #include <asm/io.h> void writ ...
- 解决Ubuntu下Apache不解析PHP问题
这两天笔者遇到了一个很操蛋的问题——Apache无法解析PHP代码了,之前一直用的挺好的,突然就挂了,然后在网上疯狂的找解决办法,但是大都是php5的版本,而我却是7的版本,我就先顺便把5版本的解决方 ...
- CF #323 DIV2 D题
可以知道,当T较大时,对于LIS,肯定会有很长的一部分是重复的,而这重复的部分,只能是一个block中出现次数最多的数字组成一序列.所以,对于T>1000时,可以直接求出LIS,剩下T-=100 ...
- Application Framework层介绍
http://write.blog.csdn.net/postedithttp://write.blog.csdn.net/postedithttp://write.blog.csdn.net/pos ...
- powerdesigner 16.5 视图的显示
今天中午为了解说绘图.然后把toolbox跟object brower都关掉了,花了1个小时才找到toolbox 1.object brower显示 直接使用快捷键 ALT+0 2.toolbox(也 ...