目录:

  sql语句

  sql命令语句

  关键字

   

sql语句

SELECT * FROM V$reserved_words;--查询oracle预留关键字

SELECT * FROM V$version;--查询oracle版本

select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b.object_id = a.object_id;  --查看被锁的表名

SELECT * FROM user_col_comments WHERE table_name='****'; --查询表的列 ,表名区分大小写

select  * from user_tab_comments;----查询所有表

select  *  from user_tab_comments  where Table_Name='****';----查询某一个表的名称及备注

-- 创建主键  

ALTER TABLE USER ADD CONSTRAINTS pk_user PRIMARY KEY(user_id);
ALTER TABLE USER DROP CONSTRAINTS pk_user;

--列修改

  • alter table [tablename] modify [column] varchar2(100);
  • alter table [tablename] add [column] varchar2(100);
  • alter table [tablename] rename column [column1] to [column2] ;
  • alter table [tablename] modify [columnname] null;  允许为null值修改
  • alter table  [tablename] add column `MODIFY_TIME`  timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '当前更新时间';   // 添加更新时间会对数据的操作直接更新时间,无需传入。

--关闭和开启触发器(用于导入数据时使用)

alter table user disable all triggers;

alter table user enable all triggers;

--加注释

COMMENT ON TABLE USER IS '用户表';
COMMENT ON COLUMN USER.USER_ID IS '主键';

sql命令语句

  • prompt
  • set feedback off/on
  • set define off/on

  prompt :

  提示的意思:

    prompt   helloworld

  将在执行台打出helloworld

  set feedback off/on(默认)

    用于设置是否有回执,我们在插入表数据时会有 1 rows inserted....,设置为off则不显示,加快执行速度。

  set define off/on(默认)

  在SQL*Plus中默认的"&"表示替代变量,只要在命令中出现该符号,SQL*Plus就会要你输入替代值。
  这就意味着你无法将一个含有该符号的字符串输入数据库或赋给变量。
  set define off 关闭替代变量。
  set define $ 用$代替&为替代常量。

关键字

  • DISTINCT
  • WITH
  • UNION
  • FUNCITON_CONCAT(str1,str2,str3)

WITH:

With

A as(select * from  a where a.name='denny'),

B as(select * from b where b.name='zhang')

select A.*,B.* from A,B where A.name = B.name;

在plsql某些版本使用with查询不到结果,有人说是plsql的bug。在Mysql中没有With的用法,其它数据库都有。With多用于复杂查询语句的嵌套或者是查询结果union用。

UNION:

SELECT emp_id,emp_name FROM emp WHERE emp_name = '张三'
UNION
SELECT emp_id personID,emp_name oaName FROM emp WHERE emp_name = '李四'
UNION ALL
SELECT emp_id person,emp_name oo FROM emp WHERE emp_name = '张三';

union中的字段数和类型要求一致,最后的结果的字段名使用第一个select的字段名UNION默认会剔除重复数据,且对结果进行排序,而UNION ALL 不做此项处理,仅对结果进行罗列。因此从性能上union all 要优于union。

FUNCITON_CONCAT(str1,str2,str3):

concat中不能存在null值,不然所有结果都为null.

DISTINCT:

DISTINCT 只能剔除所有要查询的列中一样的数据,不能查询单个列重复数据。

例: select distinct user_id,user_name,user_type from user;   user_id,user_name,user_type3个列的数据都同时相同的数据才会被剔除,而非单个列中存在重复数据。

同时DISTINCT要放置在所有查询列之前,而不能放在列中,因为它是对所有列起作用,而非单个列。

select distinct user_id,user_name  √

select  user_id,distinct user_name  ×

select count(distinct user_name) from user; √

explain:

用于查看sql的执行情况,可以分析判断sql的执行性能,用于调优。

常用Sql语句,及注意事项的更多相关文章

  1. oracle常用SQL语句(汇总版)

    Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, ...

  2. Oracle数据库常用Sql语句大全

    一,数据控制语句 (DML) 部分 1.INSERT  (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……); INSE ...

  3. Mysql 常用 SQL 语句集锦

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  4. Mysql 常用 SQL 语句集锦 转载(https://gold.xitu.io/post/584e7b298d6d81005456eb53)

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  5. 50个常用SQL语句

    50个常用SQL语句 Student(S#,Sname,Sage,Ssex) 学生表  S#学号,主键 Course(C#,Cname,T#) 课程表          C#课程号,主键 SC(S#, ...

  6. oracle sqlplus及常用sql语句

    常用sql语句 有需求才有动力 http://blog.csdn.net/yitian20000/article/details/6256716 常用sql语句 创建表空间:create tables ...

  7. 常用SQL语句(增删查改、合并统计、模糊搜索)

    转自:http://www.cnblogs.com/ljianhui/archive/2012/08/13/2695906.html 常用SQL语句 首行当然是最基本的增删查改啦,其中最重要的是查. ...

  8. oracle 常用sql语句

    oracle 常用sql语句 1.查看表空间的名称及大小 select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_sizefrom d ...

  9. Sqlite常用sql语句

    sqlite常用sql语句 --返回UTC时间 select CURRENT_TIMESTAMP; --返回本地时间 select datetime(CURRENT_TIMESTAMP,'localt ...

  10. 常用SQL语句集合

    一.数据定义 1.创建新数据库:CREATE DATABASE database_name2.创建新表:CREATE TABLE table_name (column_name datatype,co ...

随机推荐

  1. vertx.io 与nodejs 一个简单的性能比较

    vertx.io 与node 都是可以进行js运行的一个引擎,但是vertx 支持的语言相对于node 多,可以查看官网.今天下网上查询相关的信息 时来了解到vertx.io 性能比node 好,于是 ...

  2. android 学习过程中登陆失效的个人理解

    今天在学习的过程中,要做登陆失效的功能,所以就找了些资料.好好看了一下.研究了一番,慢慢的做出来了! 比方:你在一个手机端登陆了账号,在另外的一个手机端也登陆了账号,此时.前一个手机端的账号会提示登陆 ...

  3. bat生成vbs通过注册表禁用或启用USB端口

    在网上找到的资料,经过自己简单的修改调整,通过bat生成vbs文件,由vbs文件操作注册表的键值,达到启用和禁用USB端口的目的. 当然,你也可以完全使用BAT操作注册表来完成修改注册表的键值的目的, ...

  4. Array对象(prototype)

  5. HTTP协议中的长连接、短连接、长轮询、短轮询

    长连接.短连接,指的是TCP连接.长连接是为了复用TCP连接. 长轮询中,服务器如果检测到库存量没有变化的话,将会把当前请求挂起一段时间(这个时间也叫作超时时间,一般是几十秒).在这个时间里,服务器会 ...

  6. [C++ Primer] : 第14章: 重载运算符与类型转换

    基本概念 重载运算符是具有特殊名字的函数: 它们的名字由关键字operator和其后要定义的运算符号共同组成. 重载运算符函数的参数数量与该运算符作用的运算对象数量一样多. 对于二元运算符来说, 左侧 ...

  7. BASIC-16_蓝桥杯_分解质因数

    代码示例: #include <stdio.h> int i = 0 ;int Primes(int a){ for (i = 2 ; i <= a/2 ; i ++) { if ( ...

  8. 小峰mybatis(1) 处理clob,blob等。。

    一.mybatis处理CLOB.BLOB类型数据 CLOB:大文本类型:小说啊等大文本的:对应数据库类型不一致,有long等: BLOB:二进制的,图片:电影.音乐等二进制的: 在mysql中: bl ...

  9. POJ 3666 Making the Grade (线性dp,离散化)

    Making the Grade Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 131072/65536K (Java/Other) T ...

  10. python学习菜单

    一.python简介 二.python字符串 三.列表 四.集合.元组.字典 五.函数 六.python 模块 七.python 高阶函数 八.python 装饰器 九.python 迭代器与生成器  ...