SQL语言分类

数据查询语言DQL

数据操纵语言DML

数据定义语言DDL

数据控制语言DCL

1.数据查询语言DQL

数据查询语言Dor基本结构是由SELECT子句,FROM子句,WHERE子句组成的查询块:SELECT

FROM

WHERE

2.数据操纵语言DML

数据操纵语言DM主要有三种形式:

插入:工NSERT

更新:UPDATE

删除:DELETE

3.数据定义语言DDL

数据定义语言DDz用来创建数据库中的各种对象-----表、视图、索引、同义词、聚簇等如:

CREATETABLE/VIEW/ INDEX/ sYN/CLUSTER表视图索引同义词簇

DDL操作是隐性提交的!不能rollback

4.数据控制语言DCL

数据控制语言pcI用来授予或回收访问数据库的某种特权,控制数据库操纵事务发生的时间及效果,对数据库实行监视等。如:

GRANT:授权。

ROLLBACK [WORK] TO [SAVEPOINT]: 回退到某一点。回滚--ROLLBACK;回滚命令

使数据库状态回到上次最后提交的状态。其格式为:

SQL> ROLLBACK;

COMMIT [WORK]: 提交。

在数据库的插入、删除和修改操作时,只贿当务在提交到数据时才完成。在務提交前,只有操作数据库的这个人才能有权看到所做的事情,别人只有在后提交完成后才可以看到。提交数据有三种类型:显式提交、隐式提交及自动提交。分别说明这三种类型。

(1) 显式提交

用COMMIT命令直接完成的提交为显式提交。其格式为:

SQL>COMMIT;

(2)隐式提交

用SQL命令间接完成的提交为隐式提交。这些命令是:

ALTER,AUDIT,COMMENT,CONNECT,CREATE,DISCONNECT,DROP,EXIT,GPANT,NOAUDIT,QUIT,REVOKE,RENAME。

(3)自动提交

若把AUTOCOMMIT设置为ON,则在插入、修改、删除语句执行后,系统将自动进行提交,这就是自动提交。其格式为:

SQL>SET AUTOCOMMIT ON;

SQL中和%以及=和like的区别

=和like

区别:= 匹配一个精准值, like 可以匹配一个范围

_和%

区别:_ 任意匹配一个字符,% 任意匹配多个字符 

count(*)count(1)count(column)区别

ount(*)对行的数目进行计算,包含NULL

count(column)对特定的列的值具有的行数进行计算,不包含NULL值。

count()还有一种使用方式,count(1)这个用法和count(*)的结果是一样的。

性能问题

1.任何情况下SELECT COUNT(*) FROM tablename是最优选择;

2.尽量减少SELECT COUNT(*) FROM tablename WHERE COL = ‘value’ 这种查询;

3.杜绝SELECT COUNT(COL) FROM tablename WHERE COL2 = ‘value’ 的出现。

如果表没有主键,那么count(1)比count(*)快。

如果有主键,那么count(主键,联合主键)比count(*)快。

如果表只有一个字段,count(*)最快。

count(1)跟count(主键)一样,只扫描主键。count(*)跟count(非主键)一样,扫描整个表。明显前者更快一些。

你可能感兴趣的:(MySQL,sql,数据库,mysql)