当前位置:   article > 正文

mysql常用sql语句大全_SQL常用语句总结大全

mysql常用sql语句大全

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/164243?site
推荐阅读
相关标签
  

闽ICP备14008679号