Oracle 之 常用函数
SQL语句根据参数的不同,分为单行函数 和 多行函数。
[1] 单行函数:输入是一行,输出也是一行;
[2] 多行函数:输入多行数据,输出一个结果。
在执行时,单行函数是检索一行处理一次,而多行函数是将检索出来的数据分成组后再进行处理。
根据函数参数不同,SQL函数又分为数值函数、字符函数、日期函数、转换函数、聚集函数等多种。
1、数值函数:函数的输入、输出都是数值型数据
单行数字函数操作数字数据,执行数学和算术运算。所有函数都有数字参数并返回数字值。所有三角函数的操作数和值都是弧度而不是角度,oracle没有提供内建的弧度和角度的转换函数。
1.1 ABS(n) :返回n的绝对值
3.2 ACOS(n) :反余玄函数,返回-1到1之间的数。n表示弧度
select ACOS(-1) pi,ACOS(1) ZERO FROM dualPI ZERO3.14159265 0
3.3 ASIN(n) :反正玄函数,返回-1到1,n表示弧度
3.4 ATAN(n) :反正切函数,返回n的反正切值,n表示弧度。
3.5 CEIL(n) :返回大于或等于n的最小整数。
3.6 COS(n) :返回n的余玄值,n为弧度
3.7 COSH(n) :返回n的双曲余玄值,n 为数字。
select COSH(<1.4>) FROM dualCOSH(1.4)2.15089847
3.8 EXP(n) :返回e的n次幂,e=2.71828183.
3.9 FLOOR(n) :返回小于等于n的最大整数。
3.10 LN(n) :返回以e为底,n的对数,n必须大于0
3.11 LOG(m, n): 返回以m为底n的对数
3.12 MOD(m, n) :返回m除以n的余数
3.13 POWER(m,n): 返回m的n次方
3.14 ROUND(m [, n])
对m进行四舍五入(当n大于0时,将m四舍五入到小数点右边n位;当n省略时,对m取整;当n小于0时,将m四舍五入到小数点左边n位;n2必须是整数)。
select ROUND(12345,-2),ROUND(12345.54321,2) FROM dual
ROUND(12345,-2) ROUND(12345.54321,2)12300 12345.54
3.15 SIGN(n) :判断n的正负(n大于0返回1;n等于0返回0;n小于0返回-1)
3.16 SIN(n) :返回n的正玄值,n为弧度。
3.17 SINH(n) :返回n的双曲正玄值,n为弧度。
3.18 SQRT(n) :返回n的平方根,n为弧度
3.19 TAN(n): 返回n的正切值,n为弧度
3.20 TANH(n) :返回n的双曲正切值,n为弧度
3.21 TRUNC(m [, n]) :对m进行截取操作(当n大于0时,将m截取到小数点右边n位;当n省略时,截取m的小数部分;当n小于0时,将m截取到小数点左边n位;n2必须是整数)。
SQL和PL/SQL中自带很多类型的函数,有字符、数字、日期、转换、和混合型等多种函数用于处理单行数据,因此这些都可被统称为单行函数。这些函数均可用于SELECT,WHERE、ORDER BY、HAVING等子句中,例如下面的例子中就包含了TO_CHAR,UPPER,SOUNDEX等单行函数。
SELECT ename, TO_CHAR(hiredate,'day,DD-Mon-YYYY')
FROM scott.emp
WHERE UPPER(ename) Like 'AL%'
ORDER BY SOUNDEX(ename)
单行函数也可以在其他语句中使用,如update的SET子句,INSERT的VALUES子句,DELET的WHERE子句,最常用的是在SELECT语句中使用这些函数,所以我们的注意力也集中在SELECT语句中。
2、字符函数
单行字符串函数用于操作字符串数据,他们大多数有一个或多个参数,其中绝大多数返回字符串。
2.1 ASCII(char) :char是一字符串,返回字符串首字符的ASCII码值,它的逆函数是CHR()
SELECT ASCII('A') BIG_A,ASCII('z') BIG_z FROM emp
BIG_A BIG_z
65 122
2.2 CHR(n):n是一个数值,返回ASCII码值为n的字符
select CHR(65),CHR(122),CHR(223) FROM emp
CHR65 CHR122 CHR223
A z B
2.3 CONCAT(char1, char2) :用于字符串连接,返回char2与char1连接后的字符串
char1,char2均为字符串,函数将c2连接到c1的后面,如果c1为null,将返回c2.如果c2为null,则返回c1,如果c1、c2都为null,则返回null。它和操作符返回的结果相同。
select concat('slobo','Svoboda') username from dual
username
sloboSyoboda
2.4 INITCAP(char) :将字符串中每个单词的首字母大写
char为一字符串。函数将每个单词的首字母大写其它字母小写返回。单词由空格,控制字符,标点符号分隔。
select INITCAP('veni,vedi,vici') Ceasar from dual
Veni,Vedi,Vici
select INITCAP('veni vedi.vici') Ceasar from dual;
Veni Vedi.Vici
2.5 INSTR(char1, char2,[ m[, n]]) :返回指定字符串char2在字符串char1中的位置,m表示其实搜索位置,n表示char2在char1中出现的次数
char1,char2均为字符串,m,n为整数。当没有发现需要的字符时返回0,如果m为负数,那么搜索将从右到左进行,但是位置的计算还是从左到右,m和n的缺省值为1.
select INSTR('Mississippi','i',3,4) from dual ; 11
select INSTR('Mississippi','i',-2,3) from dual; 2
2.6 INSTRB(char1, char2,[ m[, n])
与INSTR()函数一样,只是他返回的是字节,对于单字节INSTRB()等于INSTR()
2.7 LENGTH(char) :char为字符串,返回char的长度,如果char为null,那么将返回null值。
select LENGTH('Ipso Facto') ergo from dual;
ergo 10
2.7 LENGTHB(char) :与LENGTH()一样,返回字节。
2.8 LOWER(char):返回char的小写字符,经常出现在where子串中
select LOWER(colorname) from itemdetail WHERE LOWER(colorname) LIKE '%white%';
Winter white
2.9 LPAD( char1, n, [ char2 ] )
char1是需要粘贴字符的字符串
n 是返回的字符串的长度,如果这个长度比原字符串的长度要短,lpad函数将会把字符串截取成长度 n;
char2是个可选参数,这个字符串是要粘贴到char1的左边,如果这个参数未写,lpad函数将会在 char1 的左边粘贴空格。
例如:
LPAD('tech', 7); 将返回' tech'
LPAD('tech', 2); 将返回'te'
LPAD('tech', 8, '0'); 将返回'0000tech'
LPAD('tech on the net', 15, 'z'); 将返回 'tech on the net'
LPAD('tech on the net', 16, 'z'); 将返回 'ztech on the net'
2.10 RPAD( char1, n, [ char2 ] )
与LPAD函数类似,用来格式化输出的结果。当输出结果位数少于规定的位数,使用LPAD函数在结果的左边添加自定义字符补齐位数, 使用RPAD函数在结果的右边添加自定义字符补齐位数。
2.11 LTRIM(char [, set]) :去掉字符串 char 左侧包含在 set 中的任何字符,直到第一个不在 set 中出现的字符为止。
先看几个实例:
select ltrim('109224323','109') from dual; 224323
再来看一个:
select ltrim('10900094323','109') from dual; 4323
按道理说应该是00094323的结果嘛~~ 再来看两个对比的:
select ltrim('10900111000991110224323','109') from dual; 224323
select ltrim('109200111000991110224323','109') from dual; 200111000991110224323
是不是有这样的疑问:为什么第二个查询语句多了一个2就没被截了呢?
再来看一个:
select ltrim('902100111000991110224323','109') from dual; 2100111000991110224323
按道理说是截109的值,为什么90也被截了?
总结:LTRIM(x,y) 函数是按照y中的字符一个一个截掉x中的字符,并且是从左边开始执行的,只要遇到y中有的字符, x中的字符都会被截掉, 直到在x的字符中遇到y中没有的字符为止函数命令才结束.
2.12 RTRIM(char [, set])
与LTRIM类似,把char 中最右边的字符去掉,使其最后一个字符不在set中,如果没有set,那么char就不会改变。
2.13 REPLACE(char1, char2, char3) :char1,char2,char3都是字符串,函数用char3代替出现在char1中的cchar2后返回。
select REPLACE('uptown','up','down') from dualREPLACEdowntown
2.14 SUBSTR(char, m [,n]) :用于获取字符串的子串,m为子串的起始位置,n为子串的长度。
c1为一字符串,i,j为整数,从c1的第i位开始返回长度为j的子字符串,如果j为空,则直到串的尾部。
select SUBSTR('Message',1,4) from dual
Mess
2.15 SUBSTRB(c1, i [,j])
与SUBSTR大致相同,只是I,J是以字节计算。
2.16 SOUNDEX()
SOUNDEX函数返回字符串参数的语音表示形式,相对于比较一些读音相同,但是拼写不同的单词是非常有用的。
SOUNDEX函数的语法:
SOUNDEX(string)
计算语音的算法:
1.保留字符串首字母,但删除a、e、h、i、o、w、y
2.将下表中的数字赋给相对应的字母
(1) 1:b、f、p、v
(2) 2:c、g、k、q、s、x、z
(3) 3:d、t
(4) 4:l
(5) 5:m、n
(6) 6:r
3. 如果字符串中存在拥有相同数字的2个以上(包含2个)的字母在一起(例如b和f),或者只有h或w,则删除其他的,只保留1个
4.只返回前4个字节,不够用0填充
示例:
soundex('two'),soundex('too'),soundex('to'),他们的结果都是T000
soundex('cap'),soundex('cup'),他们的结果都是C100
soundex('house'),soundex('horse'),他们的结果都分别是H200,H620
select SOUNDEX('dawes') Dawes, SOUNDEX('daws') Daws, SOUNDEX('dawson') from dual
Dawes Daws Dawson
D200 D200 D250
2.17 TRANSLATE(string,from_str,to_str)
执行时,translate依次检查string中的每个字符,然后查找这个字符是否在from_str中存在,如果不存在,那么这个string中的字符被保留,也就是被返回;如果存在,那么,translate会记下这个字符在from_str中的位置,然后用to_str的同样位置的字符代替string中的这个字符。
from_str可以比to_str长,也就是from_str的字符数目可以比to_str多,在from_str中多出来的字符称为"额外字符",也就是from_str中的位置在to_str中找不到的,比如
from_str 'abc123'
to_str 'abc'
这里from_str中的1的位置是4,但是to_str的总长度是3,没有4,所以在from_STR中的123都是额外字符,如果from_str中的额外字符在string中出现,那么string中这些字符将在返回时被删除。
举例如下
select translate('ab12','ab2','00') from dual;
001
这里a和b都被替换成了0,因为a在from_str中的位置是1,那么被to_str中的位置1的字符替换,b也是一样的处理,被to_str中的位置2的字符替换,依然是0。string中的1在from_str没有找到,所以被保留下来了,string中的2在from_str中找到了,但是是from_str的额外字符,因为2在from_str中的位置是3,而to_str中是没有3这个位置的,所以string中的2虽然在from_str中找到了,且处于3的位置,但是TO_STR的长度是2,没有3这个位置,所以2在返回时被删除,得到的是001。
另外to_str不能是NULL或者'',否则会返回空值,translate也不能用于CLOB(超过4000的长字符串类型)。
可以如下理解:
[1] 如果string中的字符如果在from_string中没有,那么返回时被保留;
[2] 如果string中的字符是from_string中的"额外字符",那么返回时被删除;
[3] 如果string中的字符在from_string中找到,且在to_string中有相应位置的字符,返回时用to_string中的字符替换string中的字符。
2.18 TRIM([leading | trailing | both] char FROM string) :从字符串string的头、尾或两端去掉字符char。
select TRIM(' space padded ') trim from dual;
space padded
2.19 UPPER(char) :返回char的大写,常出现where子串中
select name from dual where UPPER(name) LIKE 'KI%'NAMEKING
select trunc(124.1666,-2) trunc1,trunc(124.16666,2) from dual;
TRUNC1 TRUNC(124.16666,2)
100 124.16
返回截尾到n2位小数的n1的值,n2缺省设置为0,当n2为缺省设置时会将n1截尾为整数,如果n2为负值,就截尾在小数点左边相应的位上。
4、日期函数
日期函数是指对日期进行处理的函数,函数输入为 DATE 或 TIMESTAMP 类型的数据,输出为 DATE 类型的数据(除 MONTH_BETWEEN 返回整数)。
Oracle数据库中日期的默认格式为 DD-MON-YY。可以通过设置 NLS_DATE_FORMAT 参数设置当前会话的日期格式,通过 NLS_LANGUAGE 参数设置表示日期的字符集。
ALTER SESSION SET NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS';
ALTER SESSION SET NLS_LANGUAGE='AMERIXAN';
4.1 ADD_MONTHS(d, n) :返回日期d加上n个月后的结果。i可以使任意整数。如果n是一个小数,那么数据库将隐式的他转换成整数,将会截去小数点后面的部分。
CURRENT_DATE:返回当前会话时区所对应的日期;
CURRENT_TIMESTAMO[(p)]:返回当前会话时区所对应的日期时间,p表示精度,默认值为6;
DBTIMEZONE:返回数据库所在的时区;
EXTRACT(YEAR | MONTH | DAY FROM d):从日期d中获取需要的数据(年、月、日)
4.2 LAST_DAY(d) :返回日期d所在的月份的最后一天的日期
LOCALTIMESTAMP[(p)]:返回当前会话时区所对应的日期时间,p表示精度,默认值为6;
4.3 MONTHS_BETWEEN(d1, d2) :返回d1,d2两个日期相差的月数
返回d1和d2之间月的数目,如果d1和d2的日的日期都相同,或者都使该月的最后一天,那么将返回一个整数,否则会返回的结果将包含一个分数。
4.4 NEW_TIME(d, tz1, tz2): d是一个日期数据类型,当时区tz1中的日期和时间是d时,返回时区tz2中的日期和时间。tz1和tz2时字符串。
4.5 NEXT_DAY(d, string) 返回日期d后由string指定的第一个工作日所对应的日期,string使用当前会话中给出的语言指定了一周中的某一天,返回的时间分量与d的时间分量相同。
select NEXT_DAY('01-Jan-2000','Monday') "1st Monday",NEXT_DAY('01-Nov-2004','Tuesday')+7 "2nd Tuesday") from dual;
1st Monday 2nd Tuesday
03-Jan-2000 09-Nov-2004
4.6 ROUND(d ,[ fmt ]) :返回日期的四舍五入结果,将日期d按照fmt指定的格式舍入,fmt为字符串。
4.7 SYADATE() :返回当前系统的日期时间。
可用 TO_CHAR(x [, fmt]]) 或 TO_DATE(char [,fmt])格式化日期串。
4.8 TRUNC(d , [ fmt ]) :返回截断日期时间数据.
5、转换函数
主要指将一种类型的数据转换为另一种类型的数据。在某些情况下,Oracle会隐含的转换数据类型。
CAST(expr AS datatype):将表达式expr按指定的类型返回。
5.1 CHARTORWID(char) :char一个字符串,函数将char转换为RWID数据类型。
SELECT test_id from test_case where rowid=CHARTORWID('AAAA0SAACAAAALiAAA')
5.2 CONVERT(c1, dset[, sset]) :c1尾字符串,dset、sset是两个字符集,函数将字符串c1由sset字符集转换为dset字符集,sset的缺省设置为数据库的字符集。
5.3 HEXTORAW(char) :char为16进制的字符串,函数将16进制的x转换为RAW数据类型。
5.4 RAWTOHEX(raw) :raw是RAW数据类型字符串,函数将RAW数据类转换为16进制的数据类型。
5.5 ROWIDTOCHAR(rowid) :函数将ROWID数据类型转换为CHAR数据类型。
5.6 TO_CHAR(x [, fmt]]) :
x是一个date或number数据类型,函数将x转换成fmt指定格式的char数据类型,如果x为日期nlsparm=NLS_DATE_LANGUAGE 控制返回的月份和日份所使用的语言。如果x为数字nlsparm=NLS_NUMERIC_CHARACTERS 用来指定小数位和千分位的分隔符,以及货币符号。
NLS_NUMERIC_CHARACTERS ="dg", NLS_CURRENCY="string"
5.7 TO_DATE(char [,fmt]) :c表示字符串,fmt表示一种特殊格式的字符串。返回按照fmt格式显示的c,nlsparm表示使用的语言。函数将字符串c转换成date数据类型。
TO_CLOB(cahr):将字符串转化为 CLOB 类型数据。
5.8 TO_MULTI_BYTE() :c表示一个字符串,函数将c的担子截字符转换成多字节字符。
5.9 TO_NUMBER(char [, fmt]) :c表示字符串,fmt表示一个特殊格式的字符串,函数返回值按照fmt指定的格式显示。nlsparm表示语言,函数将返回c代表的数字。
5.10 TO_SINGLE_BYTE() :将字符串c中得多字节字符转化成等价的单字节字符。该函数仅当数据库字符集同时包含单字节和多字节字符时才使用
6、其它函数
Oracle还提供了一些其他的函数。
6.1 BFILENAME( dir, filename): dir是一个Directory类型的对象,file为一文件名。函数返回一个空的BFILE位置值指示符,函数用于初始化BFILE变量或者是BFILE列。
6.2 DECODE(base_expr, expr1, value1, expr2[,value2,...default]) :
base_expr是一个表达式,exprn是一个匹配表达式,如果base_expr=exprn,则返回 valuen的值。
6.3 DUMP(,[,[,[,]]]) x是一个表达式或字符,fmt表示8进制、10进制、16进制、或则单字符。函数返回包含了有关x的内部表示信息的VARCHAR2类型的值。如果指定了n1,n2那么从n1开始的长度为n2的字节将被返回。
6.4 EMPTY_BLOB() 该函数没有参数,函数返回一个空的BLOB位置指示符。函数用于初始化一个BLOB变量或BLOB列。
6.5 EMPTY_CLOB() 该函数没有参数,函数返回一个空的CLOB位置指示符。函数用于初始化一个CLOB变量或CLOB列。
6.6 GREATEST(expr1,expr2, ...) :返回几个表达式中的最大值,每个表达式都被隐含的转换第一个表达式的数据类型,如果第一个表达式是字符串数据类型中的任何一个,那么返回的结果是varchar2数据类型,同时使用的比较是非填充空格类型的比较。
6.7 LEAST(expr1,expr2, ...) :返回几个表达式中的最小值,每个表达式都被隐含的转换第一个表达式的数据类型,如果第一个表达式是字符串数据类型中的任何一个,将返回的结果是varchar2数据类型,同时使用的比较是非填充空格类型的比较。
NULLIF(expr1, expr2):如果expr1 与 expr2相等,则返回NULL,否则返回expr1.
NVL(expr1, expr2):如果expr1为null时,返回expr22,否则返回expr1。
在如何理解NULL上开始是很困难的,就算是一个很有经验的人依然对此感到困惑。NULL值表示一个未知数据或者一个空值,算术操作符的任何一个操作数为NULL值,结果均为提个NULL值,这个规则也适合很多函数,只有CONCAT,DECODE,DUMP,NVL,REPLACE在调用了NULL参数时能够返回非NULL值。在这些中NVL函数是最重要的,因为他能直接处理NULL值。
下面我们看看emp数据表它包含了薪水、奖金两项,需要计算总的补偿
column name emp_id salary bonuskey type pk nulls/unique nn,u nnfk table datatype number number numberlength 11.2 11.2
不是简单的将薪水和奖金加起来就可以了,如果某一行是null值那么结果就将是null,比如下面的例子:
update empset salary=(salary+bonus)*1.1
这个语句中,雇员的工资和奖金都将更新为一个新的值,但是如果没有奖金,即 salary + null,那么就会得出错误的结论,这个时候就要使用nvl函数来排除null值的影响。
所以正确的语句是:
update empset salary=(salary+nvl(bonus,0)*1.1
NVL2(expr1, expr2, expr3):如果expr1为null时,返回expr3,否则返回expr2。
6.8 UID():返回唯一标示当前数据库用户的ID。
6.9 USER(0: 返回当前用户的用户名
6.10 USERENV()
基于opt返回包含当前会话信息。opt的可选值为:
ISDBA 会话中SYSDBA脚色响应,返回TRUE
SESSIONID 返回审计会话标示符
ENTRYID 返回可用的审计项标示符
INSTANCE 在会话连接后,返回实例标示符。该值只用于运行Parallel 服务器并且有 多个实例的情况下使用。
LANGUAGE 返回语言、地域、数据库设置的字符集。
LANG 返回语言名称的ISO缩写。
TERMINAL 为当前会话使用的终端或计算机返回操作系统的标示符。
6.11 VSIZE() x是一个表达式。返回x内部表示的字节数。
二、SQL中的组函数
组函数也叫集合函数,返回基于多个行的单一结果,行的准确数量无法确定,除非查询被执行并且所有的结果都被包含在内。与单行函数不同的是,在解析时所有的行都是已知的。由于这种差别使组函数与单行函数有在要求和行为上有微小的差异.
Oracle 之 常用函数的更多相关文章
- Oracle数据库常用函数
Oracle常用函数: 20.COS返回一个给定数字的余弦SQL> select cos(-3.1415927) from dual;COS(-3.1415927)--------------- ...
- 【Oracle】常用函数
来源自:https://www.cnblogs.com/lxl57610/p/7442130.html Oracle SQL 提供了用于执行特定操作的专用函数.这些函数大大增强了 SQL 语言的功能. ...
- Oracle开发常用函数与存储过程
create or replace function Fuc_Get_AuthorName(RecID_In in varchar2, AdmID_In in varchar2) return var ...
- oracle的常用函数
1. nvl NVL函数的格式如下:NVL(expr1,expr2) 含义是:如果oracle第一个参数expr1为空,那么显示第二个参数的值为expr2,如果第一个参数的值expr1不为空,则显示第 ...
- [转载]oracle的常用函数 instr() 和substr()函数
在Oracle中 可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符. 在一个字符串中查找指定的字符,返回被查找到的指定的字符的位置. 语法: instr(sourceString, ...
- oracle的常用函数 instr() 和substr()函数
from:http://1055592535.iteye.com/blog/1676235 在Oracle中 可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符. 在一个字符串中查找 ...
- oracle中常用函数
1.oracle中 trunc 是截取的函数,用在日期类型上,就是截取到的日或时间. select trunc(sysdate) from dual 默认是截取系统日期到日,得到 2012-12- ...
- Oracle数据库常用函数使用--持续更新中
NVL函数.NVL( string1, replace_with).如果string1为NULL,则NVL函数返回replace_with的值,否则返回原来的值. INSTR函数.用于查找指定字符串是 ...
- ORACLE时间常用函数(字段取年、月、日、季度)
TO_DATE格式 Day: dd number 12 dy abbreviated fri day spelled out friday ddspth spelled out, ordinal tw ...
随机推荐
- CentOS下Supervisor的安装与使用入门
[转载]http://www.51bbo.com/archives/2120 Supervisor是一个进程管理工具,官方的说法 用途就是有一个进程需要每时每刻不断的跑,但是这个进程又有可能由于各种原 ...
- Unity 2D游戏开发教程之游戏中精灵的跳跃状态
Unity 2D游戏开发教程之游戏中精灵的跳跃状态 精灵的跳跃状态 为了让游戏中的精灵有更大的活动范围,上一节为游戏场景添加了多个地面,于是精灵可以从高的地面移动到低的地面处,如图2-14所示.但是却 ...
- PHPStorm设置调试
先下载PHP扩展Xdebug https://xdebug.org, 可以复制自己的phpinfo粘贴到https://xdebug.org/wizard.php中, 会生成需要下载的版本, php. ...
- 解决关于stack溢出的问题
开发中经常遇到: 前端遇到Uncaught RangeError: Maximum call stack size exceeded错误 后台遇到java.lang.OutOfMemoryError: ...
- 【期望DP】BZOJ2318-[Spoj4060]Game with probability Problem
[题目大意] Alice和Bob在玩一个游戏.有n个石子在这里,Alice和Bob轮流投掷硬币,如果正面朝上,则从n个石子中取出一个石子,否则不做任何事.取到最后一颗石子的人胜利.Alice在投掷硬币 ...
- 11.m进制转十进制
Strlen是字符串有多长就是多长,包括所有的元素和\0这个结束符 题目描述 Description 将m进制数n转化成一个十进制数 m<=16 题目保证转换后的十进制数<=100 输入描 ...
- [转]Android x86模拟器Intel Atom x86 System Image配置与使用方法
Android x86模拟器Intel Atom x86 System Image配置与使用方法 前言: 大家现在开发使用的Android 模拟器模拟的是 ARM 的体系结构(arm-eabi),因此 ...
- Codeforces Round #346 (Div. 2) A. Round House 水题
A. Round House 题目连接: http://www.codeforces.com/contest/659/problem/A Description Vasya lives in a ro ...
- MySQL导数据工具对比
最近遇到非常多的导数据的需求(主要是CSV的需求),专门对mysqldump.pt-archive.mydumper做了一下对别,粗浅研究,以备将来使用. msqldump pt-archive ...
- POJ 1222 POJ 1830 POJ 1681 POJ 1753 POJ 3185 高斯消元求解一类开关问题
http://poj.org/problem?id=1222 http://poj.org/problem?id=1830 http://poj.org/problem?id=1681 http:// ...