SQL基础操作汇总
SQL基础操作汇总

一、表操作
1、表的创建(CREATE TABLE):
基本语句格式: CREATE TABLE table_name ( col_name datatype, ……);
解释: table_name 为要创建的表的名称(同一登录用户下表名必须唯一),col_name 为表中属性的名称,datatype 为属性的相应数据类型,同一表中会有许多字段,也可以在字段数据类型后追加各种约束条件(具体见约束)。
例:
2、表的修改(ALTER TABLE):
解释:所有对表进行修改的语句,开头均以alter table+要修改的表的名称,后面的一系列操作只需要追加相应的关键字语句即可,例如添加字段
ALTER TABLE table_name ADD col_name datatype
(修改表名)基本语句格式:RENAME table_name TO new_table_name; (TO前面为原表名,后面为新的表名)
例:
(添加字段)基本语句格式:ALTER TABLE table_name ADD col_name datatype; (add关键字为添加字段使用)
例:
(修改字段名称)基本语句格式:ALTER TABLE table_name RENAME COLUMN col_name TO new_col_name; (RENAME COLUMN为修改字段名的关键字,TO后面为新的名称,前面为原名称)
例:
(修改字段数据类型)基本语句格式:ALTER TABLE tbale_name MODIFY col_name datatype;
例:
(删除字段)基本语句格式: ALTER TABLE table_name DROP COLUMN col_name; (drop column为字段删除的关键字)
例:
3、表的删除(DROP TABLE\TRUNCATE TABLE):
①截断方式删除表:仅清空表中数据,不会删除表,也不会删除表中的字段。
基本语句格式:TRUNCATE TABLE table_name;
例:
②完全删除方式删除表:会将整个表删除,包括表中数据和表的结构、字段。
基本语句格式:DROP TABLE table_name;
例:
4、向插入数据(INSERT INTO):
①纯插入方式
基本语句格式:INSERT INTO table_name (col_name1,col_name2…… ) VALUES(value1,value2……);
解释:values前的括号内为字段名集,后面为对应的值,值的数据类型必须与字段的数据类型一致,否则无法添加,同时,根据values前括号内的内容可以进行指定字段添加,例如:仅写一个username字段,values后括号内仅一个“zhangsan”,即对单一字段添加值
例:
②复制表数据
(在创建表时进行复制)基本语句格式:CREATE TABLE table_new AS SELECT col_name1,col_name2... | * FROM table_old;
解释:将table_old表中数据复制到新表中,可以指定字段,也可全部复制,全部复制使用*,具体字段指定字段名即可。
例:
(在添加时进行复制)基本语句格式:INSERT INTO table_new (col_name1,col_name2…… ) SELECT col-name1,col-name2... | * FROM table_old;
例:
5、修改表中数据(UPDATE ):
(无条件更新)基本语句格式:UPDATE table_name SET col_name1 = value1,col_name2=value2……; (这种方式会将表中全部数据进行更新)
例:
此例中将所有password字段值设为11111
(有条件更新)基本语句格式:UPDATE table_name SET col_name1=value1,col_name2=value2.. WHERE col-name=value...
例:
6、删除表中数据(DELETE):
①删除全部数据:
基本语句格式:DELETE FROM table_name; 这一句与上文截断的结果一致,删除该表中全部数据。
②删除具体某行的数据:
基本语句格式:DELETE FROM table_name WHERE col_name=value....;
例:
二、约束
1、主键约束(PRIMARY | CONSTRAINT)
注:一张表仅能有一个主键约束,主键约束可以由多个字段构成(联合主键,复合主键)。主键约束根据关键字PRIMARY KEY 和 CONSTRAINT来实现
创建表时添加主键约束:
① CREATE TABLE table_name (col_name1 datatype PRIMARY KEY);//创建表时,直接对某一属性指定为主键
②CONSTRAINT constraint_name PRIMARY KEY (col_name1,col_name2..);//表级约束,一般在创建表时,所有字段都完成后,最后追加这个语句,如下例子:
create table userinfo(
id number(6,0),
username varchar2(20),
rank varchar2(10),
constraint pk_key (id,username),
); //其中pk_key为人为命名的主键名称
修改表时添加主键约束:ADD CONSTRAINT constraint_name PRIMARY KEY(col_name1,col_name2..);//一般跟在 ALTER TABLE table table_name后,进行主键追加,如下例子:
ALTER TABLE userinfo ADD CONSTRAINT pk_id (id );
修改主键约束名称:RENAME CONSTRAINT old_name TO new_name; //用在ALTER TABLE table_name 后面,进行主键名称的更改,如下例子:
ALTER TABLE userinfo RENAME CONSTRAINT pk_id TO pk_newid;
删除主键约束:
①DROP CONSTRAINT constraint_name ; //彻底删除名称为constraint_name的主键约束,跟在ALTER TABLE table_name 后使用。
②DISABLE|ENABLE CONSTRAINT constraint_name;//这种方式为 禁用 | 开启 主键约束,并没有实质的删除,同样是跟在ALTER TABLE table_name 语句后面使用。
2、外键约束(REFERENCES)
创建表时添加外键约束:
①CREATE TABLE table1(col_name1 datatype REFERENCES table2(col-name));//通过关键字REFERENCES,选择table2中的字段作为外键,被引用的字段必须为table2的主键
②CONSTRAINT constraint_name FOREIGN KEY( col_name1,col_name2...) REFERENCES table2(col-name,col-name)[ON DELETE CASCADE ] //表级设置,同时指定级联删除,所谓级联删除就是,我们主表中的一条数据被删除,那么从表中引用主表字段的这一行数据也会被删除(通过ON DELETE CASCADE)。
修改表时设置外键约束:ADD CONSTRAINT constraint_name FOREIGN KEY( col_name1,col_name2...) REFERENCES table2(col-name,col-name)[ON DELETE CASCADE ]//跟在修改表语句后使用
删除外键约束:
①DROP CONSTRAINT constraint_name ; //彻底删除名称为constraint_name的外约束,跟在ALTER TABLE table_name 后使用。
②DISABLE|ENABLE CONSTRAINT constraint_name;//这种方式为 禁用 | 开启 外键约束,并没有实质的删除,同样是跟在ALTER TABLE table_name 语句后面使用。
3、非空约束(NOT NULL)
创建时添加非空约束:CREATE TABLE table_name (col_name datype NOT NULL);
修改表时添加非空约束:ALTER TABLE tbale_name MODIFY col_name datatype NOT NULL;
删除非空约束:ALTER TABLE tbale_name MODIFY col_name datatype NULL;
4、唯一约束(UNIQUE)
注:唯一约束可以有多个,而主键约束仅限一个,两者都有唯一限制
创建时添加非空约束:CREATE TABLE table_name (col_name datype UNIQUE); 或者 CONSTRAINT constraint_name UNIQUE (col-name,col-name);
修改表时添加非空约束:ALTER TABLE tbale_name ADD CONSTRAINT constraint_name UNIQUE (col-name,col-name);
删除非空约束:DISABLE|ENABLE CONSTRAINT constraint_name; 或者 DROP CONSTRAINT constraint_name ;
5、检查约束(CHECK)
注:检查约束就是限制数据的实际意义,比如现实生活中工资不会出现负数,所以在表设计的时候,工资字段就要设置检查约束,使其大于等于0
创建表的时候添加检查约束:CREATE TABLE table_name (col_name datype CHECK( 具体的约束条件 )); 或者 CONSTRAINT constraint_name CHECK (条件);
修改表时添加检查约束:ALTER TABLE tbale_name ADD CONSTRAINT constraint_name CHECK (条件);
删除检查约束:DISABLE|ENABLE CONSTRAINT constraint_name; 或者 DROP CONSTRAINT constraint_name ;
三、查询
1、运算符
算数运算符: +、-、*、/
比较运算符:> , >= , < , <= , = , <> 注:主要用在where关键字后面,结果为布尔值
逻辑运算符:NOT, AND , OR 用以链接条件,对应着并,或,非。
表达式 = 操作数 + 运算符 这里的操作数在oracle中可以是变量,常量,字段
2、基本查找语句(SELECT)
基本语句格式:SELECT col-name1,col-name2... | * FROM table_name;
3、条件查询(SELECT .... WHERE ...)
基本语句格式:SELECT col-name1,col-name2... | * FROM table_name WHERE 具体的条件表达式
例如: SELECT username,password FROM userinfo WHERE id>=1 AND salary >500; //查询id大于1,工资大于500的所有用户的账号和密码信息
4、模糊查询(LIKE)
LIKE运算符可以归为比较运算符的一种,通过 LIKE 关键字配合通配符 ‘_,%’ 构成实现模糊查询的表达式,放置where后面即可。
" _ " : 一个 ' _ '仅能代替一个字符,例如 a_,代表首字母为a,后面仅有一位字符的组合。
" % ":代表0个或多个字符,不限个数,例如 %a,代表末尾为a的所有字符组合
基本语句格式:SELECT * | col-name1,col-name2... FROM table_name WHERE col-name LIKE ' 通配符组成的信息 '
例如: SELECT * FROM userinfo WHERE username LIKE ‘a% ’ //查询用户名以a为首字母的所有信息
SELECT email FROM userinfo WHERE username LIKE ‘_a% ’ // 查询用户名第二个字符为a的邮箱
SELECT username FROM userinfo WHERE username LIKE ‘%a% ’ //查询用户名中包含a字母的所有用户的用户名
5、范围查询(BETWEEN.....AND....)
主要通过 between and 的组合构成某项属性的范围条件,与之前的条件查询中运用<,>运算符进行条件查询效果一致,同时进行条件表达式组合时也可以配合NOT 进行组合,例如 NOT BETWEEN 30 AND 50,即是查小于30和大于50的范围
基本语句格式: SELECT * | col-name1,col-name2... FROM table_name WHERE col-name BETWEEN ? AND ?;
6、并表查询
并表查询主要依附于表的链接(JOIN),表的链接分为,内连接,外连接,交叉连接。
内连接基本语句格式:SELECT *FROM table1 [inner] join table2 on table1.字段1=table2.字段1....;
内连接基本语句格式2:SELECT * FROM table1,table2 WHERE table1.字段1=table2.字段1....;
交叉连接:表与表之间做笛卡儿积,SELECT * FROM table1,table2....
外连接又可细分为左外连接,右外连接和全连接
①左外连接:LEFT OUTER JOIN
左侧的表中的全部数据都会被显示出来,但是右侧表的数据,只有和左侧匹配上的字段才会被查询出来!否则都会显示null!
基本语句格式1:SELECT * FROM table1 LEFT OUTER JOIN table2 on table1.col-name1=table2.col-name1;
基本语句格式2:SELECT* FROM table1 LEFT OUTER JOIN table2 where table1.col-name1=table2.col-name1;
②右外连接:RIGHT OUTER JOIN
右侧的表中的全部数据都会被显示出来,但是左侧表的数据,只有和右侧匹配上的字段才会被查询出来!否则都会显示null!
基本语句格式1:SELECT * FROM table1 RIGHT OUTER JOIN table2 on table1.col-name1=table2.col-name1;
基本语句格式2:SELECT* FROM table1 RIGHT OUTER JOIN table2 where table1.col-name1=table2.col-name1;
③全外连接:FULL/ALL OUTER JOIN
基本语句格式:SELECT * FROM table1 FULL OUTER JOIN table2 on table1.col-name1=table2.col-name1;
SQL基础操作汇总的更多相关文章
- Oracle知识梳理(三)操作篇:SQL基础操作汇总
Oracle知识梳理(三)操作篇:SQL基础操作汇总 一.表操作 1.表的创建(CREATE TABLE): 基本语句格式: CREATE TABLE table_name ( col_ ...
- SQL字符串操作汇总
SQL字符串操作汇总 --将字符串中从某个字符开始截取一段字符,然后将另外一个字符串插入此处 select stuff('hello,world!',4,4,'****') --返回值hel*** ...
- MySQL数据分析-(8)SQL基础操作之库操作
前面我们讲了学习SQL的两个逻辑框架,jacky说了这样一个逻辑:库是为了存储表的,所以一定是先有库才有表:同样的道理,有表才有表中的数据,是吧,肯定是这个逻辑:那么,今天jacky就捋着这个逻辑从库 ...
- MySQL数据分析-(10)SQL基础操作之表操作
大家好,我是jacky,很高兴跟大家继续分享MySQL数据分析实战课程,前面我们学习了库层面增删改查的SQL语句,这次课jacky将给大家介绍表层面的增删改查, (一)本课时的学习逻辑 表层面的增删改 ...
- C# 数据操作系列 - 1. SQL基础操作
0.前言 前篇介绍了一些数据库的基本概念和以及一些常见的数据库,让我们对数据库有了一个初步的认识.这一篇我们将继续为C#数据操作的基础填上一个空白-SQL语句. SQL(Structured Quer ...
- SQL基础操作
SQL是操作数据的语言 增加记录: insert into 数据表名称(字段1,字段2,字段3....)values(值1,值2,值3.....) 查看表结构:desc 表名 inset into x ...
- Hive SQL基础操作
创建表 hive 查看本地的文件#Can execute local commands within CLI, place a command in between ! and ;!cat data/ ...
- My SQL常用操作汇总
写这篇随笔的目的是我发现了在上一篇关于My SQL的随笔中存在一些不严谨的代码问题,在这里再次简单的总结一下并加以改进,以代码为主. # !每行命令必须以分号(;)结尾 先通过命令行进入数据库客户端 ...
- SQL基础语句汇总
连接数据库 1 mysql -h10.20.66.32 -uroot -p123456 -h后面是mysqlServer所在地址,-u后面是用户名,-p后面是密码 查看数据库 1 show datab ...
随机推荐
- mysql性能优化之-innodb_flush_log_at_trx_commit
innodb_flush_log_at_trx_commit是配置MySql日志何时写入硬盘的参数: 一.参数值说明 0:log buffer将每秒一次地写入log file中,并且log file的 ...
- JavaScript 很长很长的JS
var BaiduUsers = [], WechatUsers = []; var User = function(id, name, phone, gender, age, salary) { t ...
- C++堆栈问题
编写C++中的两个类 一个只能在栈中分配空间 一个只能在堆中分配. 解答: (1)代码如下 (2)堆栈分配内存的介绍 一.一个经过编译的C/C++的程序占用的内存分成以下几个部分:1.栈区(stack ...
- 使用commons-compress操作zip文件(压缩和解压缩)
http://www.cnblogs.com/luxh/archive/2012/06/28/2568758.html Apache Commons Compress是一个压缩.解压缩文件的类库. 可 ...
- 用python抓取智联招聘信息并存入excel
用python抓取智联招聘信息并存入excel tags:python 智联招聘导出excel 引言:前一阵子是人们俗称的金三银四,跳槽的小朋友很多,我觉得每个人都应该给自己做一下规划,根据自己的进步 ...
- JBOSSAS 5.x/6.x 反序列化命令执行漏洞(CVE-2017-12149)
本文主要记录一下JBOSSAS 5.x/6.x 反序列化命令执行漏洞的测试过程 仅供学习 文中利用到漏洞环境由phith0n维护: JBoss 5.x/6.x 反序列化漏洞(CVE-2017-1214 ...
- (转)TCP协议与UDP协议的区别
TCP协议与UDP协议的区别 首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信! ...
- 基于NetMQ的TLS框架NetMQ.Security的实现分析
基于NetMQ的TLS框架NetMQ.Security的实现分析 前言 介绍 交互过程 支持的协议 TLS协议 支持的算法 实现 握手 第一次握手 Client Hello 第二次握手 Server ...
- 前端打包工具——build release介绍
前言 对于前端开发者来说,资源打包是日常过程中一个必不可少的过程:目前我们大多数时候使用grunt.gulp.webpack这三个工具来完成这个工作:但是有一个特点就是我们没创建一个项目都要对应的去编 ...
- [ Java面试题 ] 框架篇
1.谈谈你对Struts的理解. 1. struts是一个按MVC模式设计的Web层框架,其实它就是一个Servlet,这个Servlet名为ActionServlet,或是ActionServlet ...