转自   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>的更多相关文章

  1. Oracle SQL性能优化技巧大总结

    http://wenku.baidu.com/link?url=liS0_3fAyX2uXF5MAEQxMOj3YIY4UCcQM4gPfPzHfFcHBXuJTE8rANrwu6GXwdzbmvdV ...

  2. 【转】PL/SQL Developer使用技巧、快捷键

    原文链接:PL/SQL Developer使用技巧.快捷键 1.类SQL PLUS窗口:File->New->Command Window,这个类似于oracle的客户端工具sql plu ...

  3. mysql操作sql的小技巧

    本篇集中整理一下执行sql的小技巧,这种方式不仅带来了操作上的便捷,也可以保证数据可以数据的安全性. 1:查询数据(保证查询性能) 首先想先解释一下 SELECT * 和 SELECT t.id , ...

  4. PL/SQL Developer使用技巧(部分)

    PL/SQL Developer使用技巧(部分) 关键字自动大写 在sql命令窗口中输入SQL语句时,想要关键字自动大写,引人注目该怎么办呢? 一步设置就可以达成了.点击Tools->Prefe ...

  5. SQL高级查询技巧

    SQL高级查询技巧   1.UNION,EXCEPT,INTERSECT运算符 A,UNION 运算符 UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重 ...

  6. 【SQL实践】其他常用SQL汇总

    [SQL实践]其他常用SQL汇总 1.联表更新 update students stu inner join course on course.STUDENT_ID=stu.id set stu.na ...

  7. 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 ...

  8. sql server 小技巧(2) 删除sql server中重复的数据

    with list_numbers as ( select Name, AuthorOrTime, Url, Price, EstimatePrice, Size, Category, ROW_NUM ...

  9. sql server 小技巧(1) 导入csv数据到sql server

    1. 右击 DataBaseName,选择 Tasks->Import Data 2. 选择数据源: Flat File Source , 选择一个csv文件 Advance: 选择所有的列,改 ...

随机推荐

  1. learning scala 变量

    scala 变量: val : 声明时,必须被初始化,不能再重新赋值. scala> test = "only1"<console>:11: error: not ...

  2. CF 463A && 463B 贪心 && 463C 霍夫曼树 && 463D 树形dp && 463E 线段树

    http://codeforces.com/contest/462 A:Appleman and Easy Task 要求是否全部的字符都挨着偶数个'o' #include <cstdio> ...

  3. 【转载】oracle索引详解2

    原文URL:http://justplayoop1.iteye.com/blog/1259562 一. 索引介绍 1.1  索引的创建 语法 : CREATE UNIUQE | BITMAP INDE ...

  4. fluent nhibernate映射的数值类型问题

    fluent nhibernate中,数值类型设置不当,就可能会引发一些意想不到错误. 一.引发映射错误 比如,oracle数据库中,字段ID类型是number,结果用codesmith生成代码,实体 ...

  5. ZooKeeper安装,部署

    实验环境 192.168.1.10 Zookeeper1:2181, Zookeeper2:2182 192.168.1.11 ZooKeeper3:2181 依赖环境 JDK1.7 安装,配置 1. ...

  6. chapter02 朴素贝叶斯分类器对新闻文本数据进行类型预测

    基本数学假设:各个维度上的特征被分类的条件概率之间是相互独立的.所以在特征关联性较强的分类任务上的性能表现不佳. #coding=utf8 # 从sklearn.datasets里导入新闻数据抓取器f ...

  7. 更适合程序员使用的Vim配置 显示行号 语法高亮 智能缩进

    在终端下使用vim进行编辑时,默认情况下,编辑的界面上是没有显示行号.语法高亮度显示.智能缩进等功能的.为了更好的在vim下进行工作,需要手动设置一个配置文件:.vimrc.在启动vim时,当前用户根 ...

  8. centos配置ruby开发环境(转 )

    转自http://my.oschina.net/u/1449160/blog/260764   1. 安装ruby 1.1 yum安装,版本旧 #yum install ruby ruby-devel ...

  9. java面试题12

    1.  jsp与servlet的区分? 答:Servlet和JSP都是基于java语言上的动态网页技术,Servlet程序其实就是java程序,只不过它所使用的类库为JAVA Servlet API, ...

  10. C# 使用GZip对字符串压缩和解压

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.I ...