SQL 实践和技巧 <2>
转自 http://i.cnblogs.com/EditPosts.aspx?opt=1
几个小技巧
(1)||的使用:
select ‘(‘||phone[1,3]||’)’phone[5,12], from customer where customer_num=106;
Result:(415)389-8789
(2)TRIM的使用:select trim(fname) from customer; 删除前导和后继空格。
select trim(leading ‘1’ from phone) from customer;
返回值中若phone字段以字符’1’开始,则删除字符’1’。
(3)SERAIL值的插入:tt中有两个字段,字段c1是serail ,字段c2是char(8);
insert into tt values(0, ‘AA’);insert into tt values(0, ‘BB’);
select * from tt;得到结果:1 AA, 2 BB;
对于SERIAL的字段,插入0表示由数据库系统自动插入序列值。
(4)DELIMITER的使用:
在LOAD和UNLOAD中指定字段值之间的间隔采用的字符
缺省时采用字符’|’。如:unload to ‘next.txt’ delimiter ‘;’ select * from tt ;
但不能使用'\', hex digits, tab 或 space。
(5)UNION和UNION ALL:
要求查询返回的结果名字、类型相同;前者不重复,后者显示重复值。
在SELECTs 中使用 sorts 或 joins
如果在SELECTs 中使用 sorts 或 joins可以使用临时表 例:
SQL1:
SELECT time_records.*, case_name
FROM time_records, OUTER cases
WHERE time_records.client = "AA1000"
AND time_records.case_no = cases.case_no
ORDER BY time_records.case_no
SQL2:
SELECT time_records.*, case_name
FROM time_records, OUTER cases
WHERE time_records.client = "AA1000"
AND time_records.case_no = cases.case_no
INTO temp foo;
SELECT * from foo
ORDER BY case_no
说明:语句二比语句一将更节省时间。
SELECTs 中使用 NOT IN or NOT EXISTS 子句
例:SQL1:(这条语句的执行将会很费时)
SELECT code FROM table1
WHERE code NOT IN ( SELECT code FROM table2 ) ;
SQL2:
SELECT code, 0 flag FROM table1 INTO TEMP tflag;
UPDATE tflag SET flag = 1
WHERE code IN
( SELECT code FROM table2 WHERE tflag.code = table2.code );
SELECT * FROM tflag WHERE flag = 0;
说明:大多数情况下语句二比语句一将更有效,但若table1.code和table2.code均有索引,
可能效果不明显。
SET EXPLAIN ON的使用
"SET EXPLAIN ON" 是一个 SQL命令,它将产生文件sqexplain.out,其中含有SQL命令的诊断信息,'cost' 会指出命令的估计用时(有时可能有较大偏差)。
避免使用 "OR"
例:WHERE a = "B" OR a = "C"将比WHERE a IN ("B","C")慢 另外,有时使用UNION将比OR有效。
关于索引
在joined 和ORDER BY的字段上加索引,WHERE子句涉及的字段也可以尽量加索引
AND和BWTWEEN的使用
例:
WHERE datecol >= "this/date" AND datecol <= "that/date"将比
WHERE datecol BETWEEN "this/date" AND "that/date"慢
在CLAC字段上建立视图
CREATE VIEW tst AS
SELECT ship_charge - totval cout
FROM orders WHERE ship_charge > 0;
应改为
CREATE VIEW tst (cout) AS
SELECT ship_charge - totval
FROM orders WHERE ship_charge > 0;
如何存取当前库以外的数据?
在OnLine版本中,使用下列语句
SELECT * FROM dbname@server:owner.tablename
注: 当前库与dbname@server必须保持日志一致,即同为有日志或无日志。
"@server"和"owner."是可选的
某些OnLine版本中也可以使用同义名,如下
eg: CREATE SYNONYM Owner1.Table1 FOR Database2@Machine2:Owner2.Table2
在主表中查询从表中没有的数据
例:
SQL1:
SELECT * FROM invlin WHERE invlin.invoice NOT IN
(SELECT invmst.invoice FROM invmst)
优化后的SQL2
SELECT invmst.*, invlin.invoice inv_invoice
FROM invmst, outer invlin
WHERE invmst.invoice = invlin.invoice
INTO TEMP lone_invoices;
SELECT <whatever you need>
FROM lone_invoices
WHERE (inv_invoice IS NULL)
怎样返回SELECT语句中正常返回记录数的一部分?
例:
SQL1:
SELECT firstname, lastname, city, state
FROM bigdatabase
WHERE state = "TX"
使用语句
SELECT firstname, lastname, city, state
FROM bigdatabase
WHERE state = "TX"
AND rowid=(trunc(rowid/x)*x)
其中x是查询部分的比例1/x,注意只能作到大约比例,且不保证随机性.
如何创建与与永久表一样的结构
例:
SQL1:
CREATE TEMP TABLE mytemp (prodno LIKE product.prodno desc LIKE product.desc)
SQL2:
SELECT prodno, desc FROM product
WHERE ROWID = -1
INSERT INTO TEMP mytemp
两种方法都正确,你选择那一个?
怎样更改序列值
例:
改变自动生成的序列值的起始值(由小的序列值改为大的序列值):
ALTER TABLE tablename MODIFY( ser_col_name SERIAL(new_start_number))
改自动生成的序列值的起始值为1(由大的序列值改为小的序列值):
先改为1,再改为指定的值
INSERT INTO tablename (serial_column) VALUES (2147483647);
INSERT INTO tablename (serial_column) VALUES (0); -- Back to 1 again!
ALTER TABLE tablename MODIFY( ser_col_name SERIAL(new_start_number))
加速SELECT COUNT(UNIQUE)?
例:
SQL1: select count(unique xxx) ... 执行了约30分钟.
SQL2: select unique xxx ... into temp aa; select count(*) from aa; 执行了7分钟
SQL 实践和技巧 <2>的更多相关文章
- Oracle SQL性能优化技巧大总结
http://wenku.baidu.com/link?url=liS0_3fAyX2uXF5MAEQxMOj3YIY4UCcQM4gPfPzHfFcHBXuJTE8rANrwu6GXwdzbmvdV ...
- 【转】PL/SQL Developer使用技巧、快捷键
原文链接:PL/SQL Developer使用技巧.快捷键 1.类SQL PLUS窗口:File->New->Command Window,这个类似于oracle的客户端工具sql plu ...
- mysql操作sql的小技巧
本篇集中整理一下执行sql的小技巧,这种方式不仅带来了操作上的便捷,也可以保证数据可以数据的安全性. 1:查询数据(保证查询性能) 首先想先解释一下 SELECT * 和 SELECT t.id , ...
- PL/SQL Developer使用技巧(部分)
PL/SQL Developer使用技巧(部分) 关键字自动大写 在sql命令窗口中输入SQL语句时,想要关键字自动大写,引人注目该怎么办呢? 一步设置就可以达成了.点击Tools->Prefe ...
- SQL高级查询技巧
SQL高级查询技巧 1.UNION,EXCEPT,INTERSECT运算符 A,UNION 运算符 UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重 ...
- 【SQL实践】其他常用SQL汇总
[SQL实践]其他常用SQL汇总 1.联表更新 update students stu inner join course on course.STUDENT_ID=stu.id set stu.na ...
- sql server 小技巧(8) visual studio 2013里使用Sql server compact 4.0及发布问题处理
1. 安装 Microsoft SQL Server Compact 4.0 https://www.microsoft.com/zh-cn/download/confirmation.aspx?i ...
- sql server 小技巧(2) 删除sql server中重复的数据
with list_numbers as ( select Name, AuthorOrTime, Url, Price, EstimatePrice, Size, Category, ROW_NUM ...
- sql server 小技巧(1) 导入csv数据到sql server
1. 右击 DataBaseName,选择 Tasks->Import Data 2. 选择数据源: Flat File Source , 选择一个csv文件 Advance: 选择所有的列,改 ...
随机推荐
- div始终在底部
<style type="text/css">body{margin:0;padding:0; } html,body{height:100%;}div{width:1 ...
- IE11浏览器,按F12 检查元素,工具会出来,但是没法正常使用?
微软网站上找到IE11的累计安全更新,安装后就能正常使用了.https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=45154
- selenium(四)操作cookie,伪造cookie
简介: Cookie,有时也用其复数形式 Cookies,指某些网站为了辨别用户身份.进行 session 跟踪而储存在用户本地终端上的数据. 常见的用途就是保留用户登陆信息,登陆时的7天免登陆,记住 ...
- Oracle导出空表解决办法
在oracle 11g 中,发现传统的exp不能导出空的表 oracle 11g 新增了一个参数:deferred_segment_creation,含义是段延迟创建,默认是true.具体是什么意思呢 ...
- hibernate 各种主键生成策略(转)
http://www.cnblogs.com/kakafra/archive/2012/09/16/2687569.html 1.assigned 主键由外部程序负责生成,在 save() 之前必须指 ...
- 安装mysql,mysql创建数据库,创建用户及为用户添加权限
安装mysql a.下载源 wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm b.安装 rpm -ivh mysq ...
- phpstorm 破解方法
前提概要:我收到博友:3102009292 的消息,发给我另一个破解PHPstorm的方法,我亲测有效,方便快捷,在和博友商量后,决定加入我的本文章中,供更多的开发者参考,话不多说,重点来了. 按照P ...
- Avito Cool Challenge 2018(div1+2)
A. Definite Game: 题意:输入N,输出最小的结果N-x,其中x不少N的因子. 思路:N=2时,输出2:其他情况输出1:因为N>2时,N-1不会是N的因子. #include< ...
- 辞树的QAQ水题(字符串统计,思维)
思路:统计一串字符有多少个'A',并分别统计出每个'A'前后有多少'Q'.然后让每个'A'前后的'Q'相乘并相加就能得出结果了. 注意:数据的类型,卡了int,要用long long. 还有就是在pc ...
- sublime text 3 实用的快捷键
Ctrl+Shift+P:打开命令面板Ctrl+P:搜索项目中的文件Ctrl+G:跳转到第几行Ctrl+W:关闭当前打开文件Ctrl+Shift+W:关闭所有打开文件Ctrl+Shift+V:粘贴并格 ...