时间:2021-07-01 10:21:17 帮助过:9人阅读
介绍参见:http://www.cnblogs.com/henryhappier/archive/2010/07/05/1771295.html
例:create database 库名称;
例:create table 表名称
(
列名称1 数据类型 约束,
列名称2 数据类型 约束1 约束2,
列名称3 数据类型,
...
)
例1:-- 以下为MySQL实现,sql server和Oracle实现为在数据类型后直接加unique
create table 表名称
(
列名称1 数据类型,
列名称2 数据类型,
列名称3 数据类型,
unique (列名称1)
)
例2:需要命名 unique 约束,以及为多个列定义 unique 约束,请使用下面的 SQL 语法
create table 表名称
(
列名称1 数据类型,
列名称2 数据类型,
列名称3 数据类型,
constraint uc_约束名 unique (列名称1,列名称2)
)
例子参考unique
例1:-- 以下为MySQL实现,sql server和Oracle实现为在数据类型后直接加约束
create table 表名称1
(
列名称1 数据类型,
列名称2 数据类型,
列名称3 数据类型,
foreign key(列名称1) references 表名称2(主键列名称)
)
例2:需要命名 foreign key 约束,以及为多个列定义 foreign key 约束,请使用下面的 SQL 语法
create table 表名称
(
列名称1 数据类型,
列名称2 数据类型,
列名称3 数据类型,
constraint fk_约束名 foreign key(列名称1) references 表名称2(主键列名称)
)
例子参考unique,check (列名称 > 值)
(1)建表时,数据类型后面加 default ‘值‘
(2)通过使用类似 GETDATE() 这样的函数,DEFAULT 约束也可以用于插入系统值。建表时在数据类型后加 default getdate()
(1)MySQL中是increment,SQL Server中是identity,oracle比较复杂
(2)increment=10,指定从10开始,每增加一条新记录自动加1
(3)identity(20,10),以 20 起始且递增 10
例1:create index index_索引名 on 表名称(列名称1,列名称2,...); -- 列名称,规定需要索引的列
例2:create index index_索引名 on 表名称(列名称 desc); -- 以降序索引某个列中的值
例3:create unique index index_索引名 on 表名称(列名称); -- 创建一个唯一的索引。唯一的索引意味着两个行不能拥有相同的索引值
例:drop database 数据库名;
例1:drop table 表名称; -- 表的结构、属性以及索引也会被删除
例2:truncate table 表名称; -- 仅删除表内的数据,但并不删除表本身
例1:alter table 表名称 drop index 索引名; -- MySQL
例2:drop index 索引名; -- Oracle
例3:drop index 表名称.索引名; -- SQL Server
例:alter table 表名称 add 列名称 数据类型;
例:alter table 表名称 drop 列名称 数据类型; --某些数据库系统不允许这种在数据库表中删除列的方式
例:alter table 表名称
alter column 列名称 数据类型;
例1:alter table 表名称 add constraint chk_约束名 check (列名称 = 值); -- 增加check约束
例2:alter table 表名称 alter column 列名称 set default ‘值‘; -- 增加default约束
例3:alter table 表名称 drop foreign key fk_约束名; -- 撤销外键约束
例2:alter table 表名称 alter column 列名称 drop default; -- 撤销default约束
例:select 列1,列2,... into 表back_up from 表名称1;
select * from 表名称;
insert into 表名称 value (值1,值2,...); 或者:insert into 表名称(列1,列2,...) value (值1,值2,...);
删除某些行:delete from 表名称 where 列名称 = 值;
删除所有行:delete from 表名称; 或者:delete * from 表名称;
update 表名称 set 列1 = 新值1, 列2 = 新值2,... where 列名称 = 值;
例:select distinct 列1 from 表名称; -- 返回列1中不同的值
例1:select 列1 from 表名称 order by 列2 desc; -- 返回的列1的记录按照列2降序排序
例2:select 列1 from 表名称 order by 列2 desc; -- 返回的列1的记录按照列2升序排序
例:select 列1,sum(列2) from 表名称 group by 列1; -- 根据列1分组显示对应的列2的总数
例:select 列1,avg(列2) from 表名称 group by 列1 having avg(列2)>60;
注:WHERE语句在GROUP BY语句之前;SQL会在分组之前计算WHERE语句。
HAVING语句在GROUP BY语句之后;SQL会在分组之后计算HAVING语句。
例1:select top 2 from 表名称 where 列名称 = 值; -- 查询前两行记录
MySQL也可用limit:select * from 表名称 limit=2; -- limit2,4返回2-4行记录
oracle也可用rownum或colnum:select * from 表名称 where rownum<=2;
例2:select top 20 percent from 表名称 where 列名称 = 值; -- 查询20%的记录
例:select * from 表名称 where 列名称 like ‘值%‘;
例1:select * from 表名称 where 列名称 in (‘值1‘,‘值2‘,...); -- 在where子句中规定多个值,可与not一起使用
例2:select * from 表名称 where 列名称 between ‘值1‘ and ‘值2‘; -- 在where子句中规定值的范围,可与not一起使用
例:select A.列1,B.列2 from 表名称 A left join 表名称 B on A.列C=B.列D;
注:JOIN: 如果表中有至少一个匹配,则返回行
LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行
RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
FULL JOIN: 只要其中一个表中存在匹配,就返回行
例:select 列1,列2 from 表名称1
union
select 列1,列2 from 表名称2;
注:UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。
默认地,UNION 操作符选取不同的值。如果允许重复的值,请使用 UNION ALL。
SQL笔记
标签:creat 数据类型 div 索引 复杂 ref html 数据库表 建表