美文网首页
SQL常用语句总结大全

SQL常用语句总结大全

作者: 谭鱼鱼 | 来源:发表于2017-07-04 11:38 被阅读0次

    mysql和oracle语法都差不多,但还是有差别,查阅资料后我总结了一套完整的sql语句大全,供初学者学习

    1.SQL是用于访问和处理数据库的标准计算机语言-------结构化查询语言(Structured Query Language)
    RDBMS:关系型数据库管理系统,是sql基础,有 MS SQL Server、IBM DB2、Oracle、MySQL等

    2.语法:
    表是相关数据的集合,由行和列组成
    SQL不区分大小写
    SELECT - 从数据库中提取数据 UPDATE - 更新数据库中的数据
    DELETE - 从数据库中删除数据 INSERT INTO - 向数据库中插入新数据
    CREATE DATABASE - 创建新数据库 ALTER DATABASE - 修改数据库
    CREATE TABLE - 创建新表 ALTER TABLE - 变更(改变)数据库表
    DROP TABLE - 删除表 CREATE INDEX - 创建索引(搜索键)
    DROP INDEX - 删除索引

    3.查询-----select
    (1)select----从数据库选取数据
    select 列名 from 表名------------------查询指定的列的数据
    select * from 表名------------------------查询整张表

    (2)distinct :一列可能有多个重复值,distinct返回唯一不同的值,即去重复
    select distinct 列名 from 表名-----------查询指定列的唯一不同的数据

    (3)where:过滤条件
    例:SELECT * FROM web WHERE country='成都';
    字符串需要用引号,数字不需要引号
    select * from 表名 where 条件--------查询满足条件的所有数据
    =:等于 !=或<>:不等于 >:大于 >=:大于等于
    <:小于 <=:小于等于 between:在某个范围
    like:某种模式 in:多个可能值 like:模糊查询 not like:不匹配记录
    例:
    name 含 "oo" 的所有客户:SELECT * FROM web WHERE name LIKE '%oo%';
    name不含“00”的所有客户:SELECT * FROM web WHERE name NOT LIKE '%oo%';

    通配符:%----代替多个字符,-------替代一个字符
    M% : 以M 开头的 %M% :包含M %M
    % : 包含M并且M在倒数第二位
    _M:任一字符开头M结尾的 [ ]:字符列中任一个 [^ ]/[! ]:不在字符列任一个
    例:
    name 以 "G"、"F" 或 "s" 开始的所有网站:
    SELECT * FROM web WHERE name REGEXP '^[GFs]';
    name 不以 "G"、"F" 或 "s" 开始的所有网站:
    SELECT * FROM web WHERE name REGEXP '[GFs]';
    注:mysql 以 REGEXP 或 NOT REGEXP 运算符 (或 RLIKE 和 NOT RLIKE) 来操作正则表达式

    in:匹配条件存在多个值
    例: name 为 "a" 或 "b" 的所有网站
    SELECT * FROM web WHERE name IN ('a','b');

    between:两个值之间的数据(不同数据库可能取边值不同)
    例: alexa 介于 1 和 20 间
    SELECT * FROM web WHERE alexa BETWEEN 1 AND 20;
    name 介于 'A' 和 'H' 之间字母:
    SELECT * FROM web WHERE name BETWEEN 'A' AND 'H';
    date 介于 '2016-05-10' 和 '2016-05-14' 之间:
    SELECT * FROM a where date BETWEEN '2016-05-10' AND '2016-05-14';

    (4)and 和or :两个及以上条件
    and:第一条件和第二个条件都成立,显示一条记录
    or :第一和第二只要一个成立,显示一条记录
    select * from 表名 where 条件1 and/or 条件2
    例:"web" 表中选取 alexa 排名大于 "15" 且国家为 "CN" 或 "USA" 的所有网站
    SELECT * FROM web WHERE alexa > 15 AND (country='CN' OR country='USA');

    (5)order by :对结果集排序,默认升序ASC,降序用DESC
    select * from 表名 order by 列名-----根据某列升序排列
    select * from 表名 order by 列名1,列名2---根据列1排序,如果数据相同按照列2排序

    (6)top子句:规定返回的记录数目(不是所有都支持)
    sql server/MS Access语法:
    select top 数字|percent 列名 from 表名
    例:"Customers" 表中选取前面 50% 的记录
    SELECT TOP 50 PERCENT * FROM web;
    mysql和oracle用其他方式:
    select 列名 from 表名 limit 数字-------mysql
    select 列名 from 表名 where rownum<=数字------oracle

    (7)别名:为表或列指定别名(使用:不止一个表,使用了函数,列名过长,需要合并多个列)
    表:select 列名 from 表名 as 表别名
    列:select 列名 as 列表名 from 表名
    例:三列(url、alexa 和 country)结合在一起,并创建一个名为 "site_info" 的别名
    SELECT name, CONCAT(url, ', ', alexa, ', ', country) AS site_info FROM web ;
    "web " 和 "access_log" 表,并分别为它们指定表别名 "w" 和 "a"
    SELECT w.name, w.url, a.count, a.date FROM web AS w, access_log AS a WHERE a.site_id=w.id and w.name="小三";

    (8)join:基于相同字段,将多个表的行结合
    inner join:若表至少一个匹配,返回行(inner join=join),没有不返回

    left join :从左表(table1)返回所有行,即使右表(table2)中没有匹配,若右表没有匹配,返回null

    right join:右表(table2)返回所有的行,即使左表(table1)中没有匹配。若左表中没有匹配,则结果为 NULL。

    full join:只要其中一个表中有匹配,返回行

    (9)union :合并两个及以上select 语句结果
    每个select语句必须有相同数量的列,列有相似的数据类型,列的顺序相同
    union默认选取不同的值,union all允许重复的值
    结果的列名等于union中第一个select语句中的列名

    4.插入-----insert into
    insert into 表名(列1,列2,列3) values (值1,值2,值3)
    id不用插入,是自动更新,唯一标识

    5.更新-----update
    update------更新(修改)已有数据
    update 表名 set 列=值 where 列=条件 (where指定条件更新,无where则全部更新)

    6.删除-----delete
    delete from 表名 where 条件-----删除满足条件的数据
    删除表中所有行(清空数据):delete from 表名 或 delete * from 表名
    还有一种方式:truncate table 表名-------删除速度快,删除表中所有内容
    drop table 表名:删除表,连表结构也删除

    7.表复制:select into
    复制一张表的数据插入到另一张新表中:create table 新表 select * from 旧表
    也可以用select into (mysql不支持,但有insert into .....select)
    select * into 新表 from 旧表---------旧表复制备份
    select 列名 into 新表 from 旧表---------旧表指定列复制到新表
    select * into 新表 from 旧表 where 1=0-------创建一个新的空表(无数据)

    8.数据复制:insert into .....select
    从一个表复制数据,插入到另一个已存在的表中
    insert into 表2 select * from 表1:复制表1所有列到表2
    insert into 表2 列名 select 列名 from 表1:复制表1的指定列插入到表2中

    9.创建数据库:create database
    create database 数据库名-----创建一个数据库

    10.创建表:create table
    create table 表名(列名1 数据类型(大小),列名2 数据类型(大小)...)
    表由行和列组成,每个表必须有表名

    11.约束Constraints:用于规定表中的数据规则
    若违反规则,行为被约束终止
    约束条件可以在建表时规定(create table)、或建表之后(alter table)
    create table 表名(列名1 数据类型(大小) 约束条件,列名2......)
    sql有以下约束:
    not null:指定某列不能存储null值,即不为空,若无添加值无法更新表

    unique:某列的每行必须有唯一的值,每个表可以有多个unique约束
    (1)create table时:
    单个:create table 表名(id int not null,...,unique (id))-------mysql
    create table 表名(id int not null unique,..., )----------其他
    多个:create table 表名(id int not null,name varchar(255) not
    null,constraint 别名 unique(id,name))
    (2)alter table时:
    单个:alter table 表名 add unique(列名)
    多个:alter table 表名 add constraint 别名 unique(列1,列2)
    (3)撤销 :
    alter table 表名 drop index 别名----------mysql
    alter table 表名 drop constraint 别名-----------其他

    primary key:某列有唯一标识,每个表只能有一个primary key约束
    主键必须包含唯一的值,主键列不能含null值,每个表只能有一个主键
    (1)create table时:
    单个:create table 表名(id int not null,...,primary key (id))---mysql
    create table 表名(id int not null primary key,...)-------其他
    多个: create table 表名(id int not null ,name varchar not
    null,...,constraint pk_id primary key (id,name))-------所有
    (这里 其实只有一个主键pk_id)
    (2)alter table时:
    单个:alter table 表名 add primary key(列名)
    多个:alter table 表名 add constraint 别名 primary key(列1,列2)
    注:必须在建表时把主键声明为不含null
    (3)撤销:
    alter table 表名 drop primary key----------mysql
    alter table 表名 drop constraint 别名-----------其他

    foreign key :外键,指向另一个表的primary key
    (1)create table时:
    单个:create table 表1(id int not null,p_id int...,primary key
    (id),foreign key(p_id) peferences 表2 (p_id))----------mysql
    create table 表1(id int not null primary key,...,p_id int foreign
    key peferences 表2 (p_id))-------其他
    (2)alter table时:
    单个:alter table 表1 add foreign key(列) references 表2(列)
    多个:alter table 表1 add constraint 别名 foreign key(列)
    references 表2(列)
    (3)撤销:
    alter table 表名 drop foreign key 别名----------mysql
    alter table 表名 drop constraint 别名------------其他

    check:值符合指定条件,同上分类
    (1)create table:
    单个:create table 表名 (p_id int not null,...,check (p_id>0))-----mysql
    create table 表名 (p_id int not null check (p_id>0),...,)-----其他
    多个: create table 表名 (p_id int,city varchar(255),...,constraint 别
    名 check (p_id>0 and city='v'))
    ( 2 ) alter table:
    单个:alter table 表名 add check (p_id>0)
    多个:alter table 表名 add constraint 别名 check (p_id>0 and city='v')
    ( 3 )撤销:
    alter table 表名 drop check 别名----------mysql
    alter table 表名 drop constraint 别名---------其他

    default:默认值
    (1)create table:
    create table 表名 (...,name varchar(255) default '张三')
    ( 2 ) alter table:
    alter table 表名 alter 列 set default '值'-----mysql
    alter table 表名 modify 列 default '值'-----oracle
    alter table 表名 alter column 列 set default '值'-----其他
    ( 3 )撤销:
    alter table 表名 alter 列 drop default----------mysql
    alter table 表名 alter column 列 drop default---------其他

    12.创建索引:create index------加速搜索、查询
    create index 索引名 on 表名(列名)-----允许重复
    create unique index 索引名 on 表名(列名)------唯一索引

    13.撤销删除:drop -----------------删除索引、表和数据库
    删除索引:drop index 索引名 on 表名---------MS Access
    drop index 表名.索引名---------sql server
    drop index 索引名--------------oracle/db2
    alter table 表名 drop index 索引名-----mysql
    删除表:drop table 表名(删除内容 : truncate table 表名)
    删除数据库:drop database 数据库名

    14、操作表:alter -----------用于已有表的添加、删除、修改列
    添加列:alter table 表名 add 列名 数据类型
    删除列:alter table 表名 drop colnum 列名
    改变列的数据类型:
    alter table 表名 alter colnum 列名 数据类型-----sql server
    alter table 表名 modify colnum 列名 数据类型-------oracle/mysql
    alter table 表名 modify 列名 数据类型------------oracle 10g后

    15.主键自动生成:auto increment --------每次插入新记录会自动创建字段的值
    create table 表名(id int not null auto_increment,....)----------------mysql
    默认开始1,每次加1,若以其他值可用auto_increment,=100
    create table 表名(id int identity(1,1) primary key,..)-------------------sql server
    identity(10,2)规定id起始为10,每次递增2
    create table 表名(id integer primary key autoincrement,....)-------Access
    默认1,每次加1,autoincrement(10,5)以10开始,每次加5

    oracle中比较复杂:
    首先创建sequence对象:
    create sequence 名字 minvalue 1 start with 1 increment by 1 cache 10
    然后插入数据的时候:
    insert into 表(id,字段2,...)values(名字.nextval,值2,...)

    16.null值:不能比较,null和0不等价
    is null: select * from 表 where 列 is null
    is not null: select * from 表 where 列 is not null
    操作null,很多时候运算需要将null转化成0,所以需要null函数:
    isnull(列,0)---------------------------------sql server/MS Access
    nvl(列,0)------------------------------------oracle
    ifnull(列,0)或coalesce(列,0)----------mysql

    相关文章

      网友评论

          本文标题:SQL常用语句总结大全

          本文链接:https://www.haomeiwen.com/subject/evithxtx.html