没有伞的孩子,必须努力奔跑!
MySQL 是一个关系型数据库,由瑞典 MySQL AB 公司开发,目前属于 Oracle 旗下公司。
MySQL默认超级管理员是root,一般在安装MySQL的时候会提示设置root密码。
前期的MySQL不支持存储过程,在MySQL5.0之后,设置存储引擎ENGINE=INNODB才能支持存储过程。
DDL—数据定义语言(Create,Alter,Drop,DECLARE)
DML—数据操纵语言(Select,Delete,Update,Insert)
DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)
常见SQL语句
1、创建用户
创建用户一般都是登录超级管理员root,进行创建之后分配权限。
username - 你将创建的用户名。host - 指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost,如果想让该用户可以从任意远程主机登陆,可以使用通配符%。password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器。
2、授权
privileges - 用户的操作权限,如SELECT , INSERT , UPDATE,DELETE 等.如果要授予所的权限则使用ALL。databasename - 数据库名,tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用表示, 如.(对所有数据库所有表相应权限),datebasename.(对指定数据库所有表相应权限)。
注意:用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令:
3、设置与更改用户密码
如果是当前登录用户用:
4、撤销用户权限
注意: 假如你在给用户’username’@’%’授权的时候是这样的(或类似的):GRANT SELECT ON testDB.user TO ‘username’@’%’, 则在使用REVOKE SELECT ON.FROM ‘username’@’%’;命令并不能撤销该用户对testDB数据库中user表的SELECT 操作。相反,如果授权使用的是GRANT SELECT ON.TO ‘username’@’%’;则REVOKE SELECT ON testDB.user FROM ‘username’@’%’;命令也不能撤销该用户对testDB数据库中user表的Select 权限。
具体信息可以用命令SHOW GRANTS FOR ‘username’@’%’; 查看。
5、删除用户
6、创建数据库-databasename - 数据库名
7、删除数据库-databasename - 数据库名
8、修改数据库名
9、备份sql server
创建 备份数据的device
开始 备份
语句1:打开系统数据库master,或者说在系统数据库下操作。
语句2:定义备份逻辑设备名testBack,类型disk,路径为e:\mysql\test.dat。
语句3:备份数据库databasename到设备testBack上。
10、创建新表
根据已有的表创建新表:
11、删除新表
12、增加一个列
注意:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
13、添加主键
14、删除主键
15、创建索引
16、删除索引
17、创建视图
18、删除视图
19、几个简单的基本的SQL语句
查询:
插入:
删除:
更新:
查找:
排序:
总数:
求和:
平均:
最大:
最小:
20、几个高级查询运算词
A: UNION 运算符
UNION运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
B: EXCEPT 运算符
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。
C: INTERSECT 运算符
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
21、使用外连接
A、LEFT OUTER JOIN:
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。
B:RIGHT OUTER JOIN:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
C:FULL OUTER JOIN:
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
22、复制表(只复制结构,源表名:a 新表名:b) (Access可用)
方法一:
方法二:
23、拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用)
24、跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用)
25、子查询(表名1:a 表名2:b)
26、between的用法,between限制查询数据范围时包括了边界值,not between不包括
27、in 的使用方法
28、两张关联表,删除主表中已经在副表中没有的信息
29、四表联查问题
30、日程安排提前五分钟提醒
31、一条sql 语句搞定数据库分页(不推荐)
32、前10条记录
33、随机取出10条数据
34、随机选择记录
35、删除重复记录
36、列出数据库里所有的表名
37、列出表里的所有的
38、收缩数据库
重建索引
收缩数据和日志
39、压缩数据库
40、转移数据库给新用户以已存在用户权限
41、检查备份集
42、修复数据库
领取专属 10元无门槛券
私享最新 技术干货