分享
 
 
 

Oracle SQL 內置函數大全

王朝oracle·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

<<Oracle SQL 內置函數大全>>幻灯片:http://www.cnblogs.com/Files/Dicky/Oracle_SQL_Function.rar

1

SQL中的单记录函数

2

1.ASCII

3

返回与指定的字符对应的十进制数;

4

SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;

5

6

A A ZERO SPACE

7

--------- --------- --------- ---------

8

65 97 48 32

9

10

11

2.CHR

12

给出整数,返回对应的字符;

13

SQL> select chr(54740) zhao,chr(65) chr65 from dual;

14

15

ZH C

16

-- -

17

赵 A

18

19

3.CONCAT

20

连接两个字符串;

21

SQL> select concat('010-','88888888')||'转23' 高乾竞电话 from dual;

22

23

高乾竞电话

24

----------------

25

010-88888888转23

26

27

4.INITCAP

28

返回字符串并将字符串的第一个字母变为大写;

29

SQL> select initcap('smith') upp from dual;

30

31

UPP

32

-----

33

Smith

34

35

36

5.INSTR(C1,C2,I,J)

37

在一个字符串中搜索指定的字符,返回发现指定的字符的位置;

38

C1 被搜索的字符串

39

C2 希望搜索的字符串

40

I 搜索的开始位置,默认为1

41

J 出现的位置,默认为1

42

SQL> select instr('oracle traning','ra',1,2) instring from dual;

43

44

INSTRING

45

---------

46

9

47

48

49

6.LENGTH

50

返回字符串的长度;

51

SQL> select name,length(name),addr,length(addr),sal,length(to_char(sal)) from gao.nchar_tst;

52

53

NAME LENGTH(NAME) ADDR LENGTH(ADDR) SAL LENGTH(TO_CHAR(SAL))

54

------ ------------ ---------------- ------------ --------- --------------------

55

高乾竞 3 北京市海锭区 6 9999.99 7

56

57

58

59

7.LOWER

60

返回字符串,并将所有的字符小写

61

SQL> select lower('AaBbCcDd')AaBbCcDd from dual;

62

63

AABBCCDD

64

--------

65

aabbccdd

66

67

68

8.UPPER

69

返回字符串,并将所有的字符大写

70

SQL> select upper('AaBbCcDd') upper from dual;

71

72

UPPER

73

--------

74

AABBCCDD

75

76

77

78

9.RPAD和LPAD(粘贴字符)

79

RPAD 在列的右边粘贴字符

80

LPAD 在列的左边粘贴字符

81

SQL> select lpad(rpad('gao',10,'*'),17,'*')from dual;

82

83

LPAD(RPAD('GAO',1

84

-----------------

85

*******gao*******

86

不够字符则用*来填满

87

88

89

10.LTRIM和RTRIM

90

LTRIM 删除左边出现的字符串

91

RTRIM 删除右边出现的字符串

92

SQL> select ltrim(rtrim(' gao qian jing ',' '),' ') from dual;

93

94

LTRIM(RTRIM('

95

-------------

96

gao qian jing

97

98

99

11.SUBSTR(string,start,count)

100

取子字符串,从start开始,取count个

101

SQL> select substr('13088888888',3,8) from dual;

102

103

SUBSTR('

104

--------

105

08888888

106

107

108

12.REPLACE('string','s1','s2')

109

string 希望被替换的字符或变量

110

s1 被替换的字符串

111

s2 要替换的字符串

112

SQL> select replace('he love you','he','i') from dual;

113

114

REPLACE('H

115

----------

116

i love you

117

118

119

13.SOUNDEX

120

返回一个与给定的字符串读音相同的字符串

121

SQL> create table table1(xm varchar(8));

122

SQL> insert into table1 values('weather');

123

SQL> insert into table1 values('wether');

124

SQL> insert into table1 values('gao');

125

126

SQL> select xm from table1 where soundex(xm)=soundex('weather');

127

128

XM

129

--------

130

weather

131

wether

132

133

134

14.TRIM('s' from 'string')

135

LEADING 剪掉前面的字符

136

TRAILING 剪掉后面的字符

137

如果不指定,默认为空格符

138

139

15.ABS

140

返回指定值的绝对值

141

SQL> select abs(100),abs(-100) from dual;

142

143

ABS(100) ABS(-100)

144

--------- ---------

145

100 100

146

147

148

16.ACOS

149

给出反余弦的值

150

SQL> select acos(-1) from dual;

151

152

ACOS(-1)

153

---------

154

3.1415927

155

156

157

17.ASIN

158

给出反正弦的值

159

SQL> select asin(0.5) from dual;

160

161

ASIN(0.5)

162

---------

163

.52359878

164

165

166

18.ATAN

167

返回一个数字的反正切值

168

SQL> select atan(1) from dual;

169

170

ATAN(1)

171

---------

172

.78539816

173

174

175

19.CEIL

176

返回大于或等于给出数字的最小整数

177

SQL> select ceil(3.1415927) from dual;

178

179

CEIL(3.1415927)

180

---------------

181

4

182

183

184

20.COS

185

返回一个给定数字的余弦

186

SQL> select cos(-3.1415927) from dual;

187

188

COS(-3.1415927)

189

---------------

190

-1

191

192

193

21.COSH

194

返回一个数字反余弦值

195

SQL> select cosh(20) from dual;

196

197

COSH(20)

198

---------

199

242582598

200

201

202

22.EXP

203

返回一个数字e的n次方根

204

SQL> select exp(2),exp(1) from dual;

205

206

EXP(2) EXP(1)

207

--------- ---------

208

7.3890561 2.7182818

209

210

211

23.FLOOR

212

对给定的数字取整数

213

SQL> select floor(2345.67) from dual;

214

215

FLOOR(2345.67)

216

--------------

217

2345

218

219

220

24.LN

221

返回一个数字的对数值

222

SQL> select ln(1),ln(2),ln(2.7182818) from dual;

223

224

LN(1) LN(2) LN(2.7182818)

225

--------- --------- -------------

226

0 .69314718 .99999999

227

228

229

25.LOG(n1,n2)

230

返回一个以n1为底n2的对数

231

SQL> select log(2,1),log(2,4) from dual;

232

233

LOG(2,1) LOG(2,4)

234

--------- ---------

235

0 2

236

237

238

26.MOD(n1,n2)

239

返回一个n1除以n2的余数

240

SQL> select mod(10,3),mod(3,3),mod(2,3) from dual;

241

242

MOD(10,3) MOD(3,3) MOD(2,3)

243

--------- --------- ---------

244

1 0 2

245

246

247

27.POWER

248

返回n1的n2次方根

249

SQL> select power(2,10),power(3,3) from dual;

250

251

POWER(2,10) POWER(3,3)

252

----------- ----------

253

1024 27

254

255

256

28.ROUND和TRUNC

257

按照指定的精度进行舍入

258

SQL> select round(55.5),round(-55.4),trunc(55.5),trunc(-55.5) from dual;

259

260

ROUND(55.5) ROUND(-55.4) TRUNC(55.5) TRUNC(-55.5)

261

----------- ------------ ----------- ------------

262

56 -55 55 -55

263

264

265

29.SIGN

266

取数字n的符号,大于0返回1,小于0返回-1,等于0返回0

267

SQL> select sign(123),sign(-100),sign(0) from dual;

268

269

SIGN(123) SIGN(-100) SIGN(0)

270

--------- ---------- ---------

271

1 -1 0

272

273

274

30.SIN

275

返回一个数字的正弦值

276

SQL> select sin(1.57079) from dual;

277

278

SIN(1.57079)

279

------------

280

1

281

282

283

31.SIGH

284

返回双曲正弦的值

285

SQL> select sin(20),sinh(20) from dual;

286

287

SIN(20) SINH(20)

288

--------- ---------

289

.91294525 242582598

290

291

292

32.SQRT

293

返回数字n的根

294

SQL> select sqrt(64),sqrt(10) from dual;

295

296

SQRT(64) SQRT(10)

297

--------- ---------

298

8 3.1622777

299

300

301

33.TAN

302

返回数字的正切值

303

SQL> select tan(20),tan(10) from dual;

304

305

TAN(20) TAN(10)

306

--------- ---------

307

2.2371609 .64836083

308

309

310

34.TANH

311

返回数字n的双曲正切值

312

SQL> select tanh(20),tan(20) from dual;

313

314

TANH(20) TAN(20)

315

--------- ---------

316

1 2.2371609

317

318

319

320

35.TRUNC

321

按照指定的精度截取一个数

322

SQL> select trunc(124.1666,-2) trunc1,trunc(124.16666,2) from dual;

323

324

TRUNC1 TRUNC(124.16666,2)

325

--------- ------------------

326

100 124.16

327

328

329

330

36.ADD_MONTHS

331

增加或减去月份

332

SQL> select to_char(add_months(to_date('199912','yyyymm'),2),'yyyymm') from dual;

333

334

TO_CHA

335

------

336

200002

337

SQL> select to_char(add_months(to_date('199912','yyyymm'),-2),'yyyymm') from dual;

338

339

TO_CHA

340

------

341

199910

342

343

344

37.LAST_DAY

345

返回日期的最后一天

346

SQL> select to_char(sysdate,'yyyy.mm.dd'),to_char((sysdate)+1,'yyyy.mm.dd') from dual;

347

348

TO_CHAR(SY TO_CHAR((S

349

---------- ----------

350

2004.05.09 2004.05.10

351

SQL> select last_day(sysdate) from dual;

352

353

LAST_DAY(S

354

----------

355

31-5月 -04

356

357

358

38.MONTHS_BETWEEN(date2,date1)

359

给出date2-date1的月份

360

SQL> select months_between('19-12月-1999','19-3月-1999') mon_between from dual;

361

362

MON_BETWEEN

363

-----------

364

9

365

SQL>selectmonths_between(to_date('2000.05.20','yyyy.mm.dd'),to_date('2005.05.20','yyyy.mm.dd')) mon_betw from dual;

366

367

MON_BETW

368

---------

369

-60

370

371

372

39.NEW_TIME(date,'this','that')

373

给出在this时区=other时区的日期和时间

374

SQL> select to_char(sysdate,'yyyy.mm.dd hh24:mi:ss') bj_time,to_char(new_time

375

2 (sysdate,'PDT','GMT'),'yyyy.mm.dd hh24:mi:ss') los_angles from dual;

376

377

BJ_TIME LOS_ANGLES

378

------------------- -------------------

379

2004.05.09 11:05:32 2004.05.09 18:05:32

380

381

382

40.NEXT_DAY(date,'day')

383

给出日期date和星期x之后计算下一个星期的日期

384

SQL> select next_day('18-5月-2001','星期五') next_day from dual;

385

386

NEXT_DAY

387

----------

388

25-5月 -01

389

390

391

392

41.SYSDATE

393

用来得到系统的当前日期

394

SQL> select to_char(sysdate,'dd-mm-yyyy day') from dual;

395

396

TO_CHAR(SYSDATE,'

397

-----------------

398

09-05-2004 星期日

399

trunc(date,fmt)按照给出的要求将日期截断,如果fmt='mi'表示保留分,截断秒

400

SQL> select to_char(trunc(sysdate,'hh'),'yyyy.mm.dd hh24:mi:ss') hh,

401

2 to_char(trunc(sysdate,'mi'),'yyyy.mm.dd hh24:mi:ss') hhmm from dual;

402

403

HH HHMM

404

------------------- -------------------

405

2004.05.09 11:00:00 2004.05.09 11:17:00

406

407

408

409

42.CHARTOROWID

410

将字符数据类型转换为ROWID类型

411

SQL> select rowid,rowidtochar(rowid),ename from scott.emp;

412

413

ROWID ROWIDTOCHAR(ROWID) ENAME

414

------------------ ------------------ ----------

415

AAAAfKAACAAAAEqAAA AAAAfKAACAAAAEqAAA SMITH

416

AAAAfKAACAAAAEqAAB AAAAfKAACAAAAEqAAB ALLEN

417

AAAAfKAACAAAAEqAAC AAAAfKAACAAAAEqAAC WARD

418

AAAAfKAACAAAAEqAAD AAAAfKAACAAAAEqAAD JONES

419

420

421

43.CONVERT(c,dset,sset)

422

将源字符串 sset从一个语言字符集转换到另一个目的dset字符集

423

SQL> select convert('strutz','we8hp','f7dec') "conversion" from dual;

424

425

conver

426

------

427

strutz

428

429

430

44.HEXTORAW

431

将一个十六进制构成的字符串转换为二进制

432

433

434

45.RAWTOHEXT

435

将一个二进制构成的字符串转换为十六进制

436

437

438

439

46.ROWIDTOCHAR

440

将ROWID数据类型转换为字符类型

441

442

443

444

47.TO_CHAR(date,'format')

445

SQL> select to_char(sysdate,'yyyy/mm/dd hh24:mi:ss') from dual;

446

447

TO_CHAR(SYSDATE,'YY

448

-------------------

449

2004/05/09 21:14:41

450

451

452

453

48.TO_DATE(string,'format')

454

将字符串转化为ORACLE中的一个日期

455

456

457

49.TO_MULTI_BYTE

458

将字符串中的单字节字符转化为多字节字符

459

SQL> select to_multi_byte('高') from dual;

460

461

TO

462

--

463

464

465

466

50.TO_NUMBER

467

将给出的字符转换为数字

468

SQL> select to_number('1999') year from dual;

469

470

YEAR

471

---------

472

1999

473

474

475

51.BFILENAME(dir,file)

476

指定一个外部二进制文件

477

SQL>insert into file_tb1 values(bfilename('lob_dir1','image1.gif'));

478

479

480

52.CONVERT('x','desc','source')

481

将x字段或变量的源source转换为desc

482

SQL> select sid,serial#,username,decode(command,

483

2 0,'none',

484

3 2,'insert',

485

4 3,

486

5 'select',

487

6 6,'update',

488

7 7,'delete',

489

8 8,'drop',

490

9 'other') cmd from v$session where type!='background';

491

492

SID SERIAL# USERNAME CMD

493

--------- --------- ------------------------------ ------

494

1 1 none

495

2 1 none

496

3 1 none

497

4 1 none

498

5 1 none

499

6 1 none

500

7 1275 none

501

8 1275 none

502

9 20 GAO select

503

10 40 GAO none

504

505

506

53.DUMP(s,fmt,start,length)

507

DUMP函数以fmt指定的内部数字格式返回一个VARCHAR2类型的值

508

SQL> col global_name for a30

509

SQL> col dump_string for a50

510

SQL> set lin 200

511

SQL> select global_name,dump(global_name,1017,8,5) dump_string from global_name;

512

513

GLOBAL_NAME DUMP_STRING

514

------------------------------ --------------------------------------------------

515

ORACLE.WORLD Typ=1 Len=12 CharacterSet=ZHS16GBK: W,O,R,L,D

516

517

518

54.EMPTY_BLOB()和EMPTY_CLOB()

519

这两个函数都是用来对大数据类型字段进行初始化操作的函数

520

521

522

55.GREATEST

523

返回一组表达式中的最大值,即比较字符的编码大小.

524

SQL> select greatest('AA','AB','AC') from dual;

525

526

GR

527

--

528

AC

529

SQL> select greatest('啊','安','天') from dual;

530

531

GR

532

--

533

534

535

536

56.LEAST

537

返回一组表达式中的最小值

538

SQL> select least('啊','安','天') from dual;

539

540

LE

541

--

542

543

544

545

57.UID

546

返回标识当前用户的唯一整数

547

SQL> show user

548

USER 为"GAO"

549

SQL> select username,user_id from dba_users where user_id=uid;

550

551

USERNAME USER_ID

552

------------------------------ ---------

553

GAO 25

554

555

556

557

58.USER

558

返回当前用户的名字

559

SQL> select user from dual;

560

561

USER

562

------------------------------

563

GAO

564

565

566

59.USEREVN

567

返回当前用户环境的信息,opt可以是:

568

ENTRYID,SESSIONID,TERMINAL,ISDBA,LABLE,LANGUAGE,CLIENT_INFO,LANG,VSIZE

569

ISDBA 查看当前用户是否是DBA如果是则返回true

570

SQL> select userenv('isdba') from dual;

571

572

USEREN

573

------

574

FALSE

575

SQL> select userenv('isdba') from dual;

576

577

USEREN

578

------

579

TRUE

580

SESSION

581

返回会话标志

582

SQL> select userenv('sessionid') from dual;

583

584

USERENV('SESSIONID')

585

--------------------

586

152

587

ENTRYID

588

返回会话人口标志

589

SQL> select userenv('entryid') from dual;

590

591

USERENV('ENTRYID')

592

------------------

593

0

594

INSTANCE

595

返回当前INSTANCE的标志

596

SQL> select userenv('instance') from dual;

597

598

USERENV('INSTANCE')

599

-------------------

600

1

601

LANGUAGE

602

返回当前环境变量

603

SQL> select userenv('language') from dual;

604

605

USERENV('LANGUAGE')

606

----------------------------------------------------

607

SIMPLIFIED CHINESE_CHINA.ZHS16GBK

608

LANG

609

返回当前环境的语言的缩写

610

SQL> select userenv('lang') from dual;

611

612

USERENV('LANG')

613

----------------------------------------------------

614

ZHS

615

TERMINAL

616

返回用户的终端或机器的标志

617

SQL> select userenv('terminal') from dual;

618

619

USERENV('TERMINA

620

----------------

621

GAO

622

VSIZE(X)

623

返回X的大小(字节)数

624

SQL> select vsize(user),user from dual;

625

626

VSIZE(USER) USER

627

----------- ------------------------------

628

6 SYSTEM

629

630

631

632

60.AVG(DISTINCT|ALL)

633

all表示对所有的值求平均值,distinct只对不同的值求平均值

634

SQLWKS> create table table3(xm varchar(8),sal number(7,2));

635

语句已处理。

636

SQLWKS> insert into table3 values('gao',1111.11);

637

SQLWKS> insert into table3 values('gao',1111.11);

638

SQLWKS> insert into table3 values('zhu',5555.55);

639

SQLWKS> commit;

640

641

SQL> select avg(distinct sal) from gao.table3;

642

643

AVG(DISTINCTSAL)

644

----------------

645

3333.33

646

647

SQL> select avg(all sal) from gao.table3;

648

649

AVG(ALLSAL)

650

-----------

651

2592.59

652

653

654

61.MAX(DISTINCT|ALL)

655

求最大值,ALL表示对所有的值求最大值,DISTINCT表示对不同的值求最大值,相同的只取一次

656

SQL> select max(distinct sal) from scott.emp;

657

658

MAX(DISTINCTSAL)

659

----------------

660

5000

661

662

663

62.MIN(DISTINCT|ALL)

664

求最小值,ALL表示对所有的值求最小值,DISTINCT表示对不同的值求最小值,相同的只取一次

665

SQL> select min(all sal) from gao.table3;

666

667

MIN(ALLSAL)

668

-----------

669

1111.11

670

671

672

63.STDDEV(distinct|all)

673

求标准差,ALL表示对所有的值求标准差,DISTINCT表示只对不同的值求标准差

674

SQL> select stddev(sal) from scott.emp;

675

676

STDDEV(SAL)

677

-----------

678

1182.5032

679

680

SQL> select stddev(distinct sal) from scott.emp;

681

682

STDDEV(DISTINCTSAL)

683

-------------------

684

1229.951

685

686

687

688

64.VARIANCE(DISTINCT|ALL)

689

求协方差

690

691

SQL> select variance(sal) from scott.emp;

692

693

VARIANCE(SAL)

694

-------------

695

1398313.9

696

697

698

65.GROUP BY

699

主要用来对一组数进行统计

700

SQL> select deptno,count(*),sum(sal) from scott.emp group by deptno;

701

702

DEPTNO COUNT(*) SUM(SAL)

703

--------- --------- ---------

704

10 3 8750

705

20 5 10875

706

30 6 9400

707

708

709

710

66.HAVING

711

对分组统计再加限制条件

712

SQL> select deptno,count(*),sum(sal) from scott.emp group by deptno having count(*)>=5;

713

714

DEPTNO COUNT(*) SUM(SAL)

715

--------- --------- ---------

716

20 5 10875

717

30 6 9400

718

SQL> select deptno,count(*),sum(sal) from scott.emp having count(*)>=5 group by deptno ;

719

720

DEPTNO COUNT(*) SUM(SAL)

721

--------- --------- ---------

722

20 5 10875

723

30 6 9400

724

725

726

67.ORDER BY

727

用于对查询到的结果进行排序输出

728

SQL> select deptno,ename,sal from scott.emp order by deptno,sal desc;

729

730

DEPTNO ENAME SAL

731

--------- ---------- ---------

732

10 KING 5000

733

10 CLARK 2450

734

10 MILLER 1300

735

20 SCOTT 3000

736

20 FORD 3000

737

20 JONES 2975

738

20 ADAMS 1100

739

20 SMITH 800

740

30 BLAKE 2850

741

30 ALLEN 1600

742

30 TURNER 1500

743

30 WARD 1250

744

30 MARTIN 1250

745

30 JAMES 950

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有