MYSQL简单的操作指南

2018-04-26  本文已影响14人  80b7b6115d87

一、MYSQL数据库管理

1. 创建MYSQL用户
CREATE USER 'reader'@'%' IDENTIFIED BY '111111';
2. 用户授权
GRANT privileges  ON database.table TO 'username'@'%'

简单示例如下:

给用户分配所有库的所有表的所有权限 ALL(所有权限),. 所有库的所有表
GRANT ALL ON . TO 'username'@'%';
给用户分配database库下所有表的所有权限 ALL(所有权限),database.* database库的所有表
GRANT ALL ON database.* TO 'username'@'%';
将自己的权限分配给别的用户
GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;
刷新系统权限表,一般在给用户分配好权限或者进行权限设置后进行操作
flush privileges
修改用户密码,要在当前用户下,修改当前密码,不是在root权限下,修改别的用户密码
SET PASSWORD = PASSWORD("newpassword");
撤销用户权限
REVOKE privilege ON databasename.tablename FROM 'username'@'host';
删除用户,用户名最好是用单引号,不用单引号有可能会报错
drop user 用户名@'%';

二、DDL语言

1. 创建数据库:
CREATE DATABASE [库名称] DEFAULT character set utf8;
2. 切换数据库
use [库名称]
3. 删除数据库
DROP DATABASE [库名称]
4. 创建表
CREATE TABLE [表名称](    
        id bigint not null primary key AUTO_INCREMENT COMMENT '主键',    
        name varchar(255) not null COMMENT '名称'    
) ENGINE=InnoDB  AUTO_INCREMENT=1000 DEFAULT charset=utf8 COMMENT='表的描述';
5. 显示表结构
SHOW CREATE TABLE [表名称]\G
6. 删除表
DROP TABLE [表名称]
7. 更新表的列的约束条件
ALTER TABLE [表名] modify [列名] [修改的条件]
8. 修改表的名称和约束条件
ALTER TABLE [表名] change [源列名] [新列名] [约束条件]
9. 添加表的列
ALTER TABLE add [列名] [约束条件]
10. 删除表的列
ALTER TABLE DROP [列名]
11. 创建表中列的索引
ALTER TABLE [表名] add index ["自定义索引名称"] ("表中需要添加索引的列名")
12. 删除索引
ALTER TABLE [表名] DROP index ["自定义的索引名称"]
13. 添加外键约束
CREATE TABLE Persons(
    id_p bigint not null primary key AUTO_INCREMENT COMMENT '主键',
    last_name varchar(255) not null COMMENT '名称'
);

table2:Orders

CREATE TABLE Orders(
    id_o bigint not null primary key AUTO_INCREMENT COMMENT '主键',
    order_no bigint not null COMMENT '订单号',
    id_p bigint not null COMMENT '外键指向Persons表的主键id_p'
);

给Orders表id_p添加外键约束,关联Persons表的主键id_p

ALTER TABLE Orders ADD FOREIGN KEY (id_p) REFERENCES Persons(id_p);
CREATE TABLE Persons(
    id_p bigint not null primary key AUTO_INCREMENT COMMENT '主键',
    last_name varchar(255) not null COMMENT '名称'
);

table2:Orders

CREATE TABLE Orders(
    id_o bigint not null primary key AUTO_INCREMENT COMMENT '主键',
    order_no bigint not null COMMENT '订单号',
    id_p bigint not null COMMENT '外键指向Persons表的主键id_p',
    FOREIGN KEY (id_p) REFERENCES Persons(id_p)
);
14. 撤销外键约束
ALTER TABLE Orders DROP FOREIGN KEY Orders_ibfk_1

注意:Orders_ibfk_1 是我们添加外键的时候由于我们没有指定外键名称,数据库就会默认生成一个外键名称,可以通过SHOW CREATE TABLE [表名称]\G 命令查看生成的外键的名称,然后在使用上面的命令进行删除Orders表的外键操作。

三、DML语言

1. 查询SELECT
SELECT [列名:a,b,c] FROM [表名:a,b,c] [限制条件……]
1.算数运算符 + - * /
2.取别名:可以给列和表取别名
                --> 直接取别名在列名的后面  last_name ln
                --> 使用as取别名         last_name as ln
                --> 使用双引号""         last_name "ln"


3.连接符 || oracle可以,mysql查询出来的数据不是我们想要的

4.过滤和排序
                --> 限制条件 多表联查的时候如果不加限制条件会出现笛卡尔积的问题
                --> 排序 order by :一般情况放在结果集最后进行排序 默认升序ASC 降序:DESC

5.运算符 > ,<, <=, >=, <>(!=)

6.其他运算符 
                --> BETWEEN……AND…… 包含边界
                --> IN([参数])
                --> IS NULL
                --> LIKE : 模糊匹配 _:代表任意一个 %:任意一个或多个

7.逻辑运算符:
                --> AND
                --> OR
                --> NOT



8.多表查询
                --> 等值连接
                --> 非等值连接
                --> 多个连接条件用AND 操作符
                --> 连接分类
                    --内连接
                    --外连接
                    --满连接



9.分组函数
                --> avg()
                --> sum()
                --> max()
                --> min()
                --> count()

10. 组函数 group by
                --> 所有包含于SELECT 列表中,而未包含于组函数中的列都必须包含于 GROUP BY 子句中
                注意: WHERE 子句后不能使用组函数,如果使用组函数使用HAVING子句


11.子查询
                --> 子查询要放在括号()中
                --> 子查询要放在查询条件的右侧
                --> 查询结果集要一对一,多对多
2. 插入 INSERT
INSERT INTO [表名] ([列名1,列名2,列名3,列名4,……]) VALUES([列值1,列值2,列值3,列值4,……]),([列值1,列值2,列值3,列值4,……]),……
3. 更新 UPDATE
UPDATE [表名称] SET [列名1]=[列值1],[列名2]=[列值2],…… [限制条件]
4. 删除 DELETE
DELETE FROM [表名称] [限制条件]
上一篇 下一篇

猜你喜欢

热点阅读