#创建一个用户并设置密码,注意IP地址要是登录mysql电脑的IP地址

USE mysql

CREATE USER lisi@'192.168.149.1' IDENTIFIED BY "111111"

CREATE USER lisi1@'192.168.149.10' IDENTIFIED BY "111111"

SELECT * FROM USER

#删除一个用户

DROP USER zhangsan@"192.168.149.1"

DROP USER lisi1@"192.168.149.10"

DELETE FROM USER WHERE USER="lisi1"

SELECT * FROM USER

#修改密码

UPDATE USER SET PASSWORD=PASSWORD("123456") WHERE USER="lisi"

#使新密码立即生效

FLUSH PRIVILEGES

#给lisi@"192.168.149.1"授权能查询test1数据库中的table1表的id属性

GRANT SELECT(id) ON test1.table1 TO "lisi"@"192.168.149.1" IDENTIFIED BY "123456"

#查看lisi@"192.168.149.1"的权限

SHOW GRANTS FOR lisi@"192.168.149.1"

#给lisi@"192.168.149.1"授权,让它能查询整个table1表的所有属性

GRANT SELECT ON test1.table1 TO "lisi"@"192.168.149.1" IDENTIFIED BY "123456"

#查看lisi@"192.168.149.1"的权限

SHOW GRANTS FOR lisi@"192.168.149.1"

#给lisi@"192.168.149.1"授权,让它能够查询test1数据库中的所有表的所有属性

GRANT SELECT ON test1.* TO "lisi"@"192.168.149.1"  IDENTIFIED BY "123456"

#查看lisi@"192.168.149.1"的权限

SHOW GRANTS FOR lisi@"192.168.149.1"

#权限没起作时,请刷新权限,如果还是不行,只能重新登录一次

FLUSH PRIVILEGES

#取消权限 ,取消对test1数据库所有表的查询权限

REVOKE SELECT ON test1.* FROM "lisi"@"192.168.149.1"    #此时,只能看到test1中的table1数据表了,看不到table2

#查看lisi@"192.168.149.1"的权限

SHOW GRANTS FOR lisi@"192.168.149.1"

#取消权限,取消对test1数据库table1中所有属性的查询权限

REVOKE SELECT ON test1.table1 FROM "lisi"@"192.168.149.1"

#查看lisi@"192.168.149.1"的权限

SHOW GRANTS FOR lisi@"192.168.149.1"

#取消权限,取消对test1数据库table1中id的查询权限

REVOKE SELECT(id) ON test1.table1 FROM "lisi"@"192.168.149.1"

#给lisi@"192.168.149.1"授权能查询test1数据库中的table1表的id和name属性

GRANT SELECT(id,NAME) ON test1.table1 TO "lisi"@"192.168.149.1" IDENTIFIED BY "123456"

#查看lisi@"192.168.149.1"的权限

SHOW GRANTS FOR lisi@"192.168.149.1"

#取消权限,取消对test1数据库table1中id的查询权限

REVOKE SELECT(id) ON test1.table1 FROM "lisi"@"192.168.149.1"   #此时lisi只能查询table1表中的name属性了,不能查询id属性了

#在定义了主键的表上,查看索引

SHOW INDEX FROM dept

#在没有定义主键的表上,查看索引

USE test1

SHOW INDEX FROM table1

#定义索引,方法1

CREATE INDEX index1 ON table1(id)

#查看索引

SHOW INDEX FROM table1

#定义索引,方法2

ALTER TABLE table2 ADD INDEX index1(id)

#查看索引

SHOW INDEX FROM table2

#定义索引,方法3

CREATE TABLE table3

(

id INT,

NAME VARCHAR(20),

INDEX index1(NAME)

)

#查看索引

SHOW INDEX FROM table3

#在table3上面删除索引

DROP INDEX index1 ON table3

#查看索引

SHOW INDEX FROM table3

#创建视图

CREATE VIEW view1

AS

SELECT * FROM table1

#通过视图查询数据

SELECT * FROM view1

#查看视图

SHOW TABLES

SHOW TABLE STATUS WHERE COMMENT="view"

#修改视图 方法1

ALTER VIEW view1

AS

SELECT * FROM table2

SELECT * FROM view1

SHOW TABLES

#修改视图 方法2

CREATE OR REPLACE VIEW view1

AS

SELECT * FROM table1

SHOW TABLES

SELECT * FROM view1

#通过视图修改原表的属性值

UPDATE view1 SET NAME="tigger" WHERE id=1

SELECT * FROM table1

SELECT * FROM view1

#对原表进行修改,视图中的数据也会修改

DELETE FROM table1 WHERE id=1

SELECT * FROM view1

#通过视图增加一行记录,原表中的记录也会增加

INSERT INTO view1 VALUES(1,"bird")

SELECT * FROM table1

#删除视图

DROP VIEW view1

SHOW TABLES

===================================================================

=========================================================

#查看函数功能的开关是否开启

SHOW VARIABLES LIKE "%func%"

#开启函数功能开关

SET GLOBAL log_bin_trust_function_creators=1

SHOW VARIABLES LIKE "%func%"

#创建函数1,不带函数

#因为sqlyog工具的原因,需要使用定界符,关键字是delimiter 后面定界符,表示程序的开始和结束

DELIMITER &

CREATE FUNCTION      helloworld()

RETURNS VARCHAR(20)

BEGIN

RETURN "hello world!";

END&

DELIMITER

#调用函数

SELECT helloworld() AS hello

#创建函数2,带参数

DELIMITER $$

CREATE FUNCTION getdate(riqi DATETIME)

RETURNS VARCHAR(50)

BEGIN

RETURN DATE_FORMAT(riqi,"%Y年%m月%d日 %h时%i分%s秒");

END$$

DELIMITER

#调用函数

SELECT getdate("2017-07-19 10:40:30")

#删除函数

DROP FUNCTION getdate

#调用函数 2

SELECT NOW()

SELECT getdate(NOW())

#查看所有函数

SHOW FUNCTION STATUS

#查看具体某个函数

SHOW CREATE FUNCTION getdate

SHOW CREATE FUNCTION helloworld

——————————————————————————————————

存储过程:

数据准备:

create database test1 default charactor set utf8 collate utf8_general_ci

create table hr

(

id int,

name varchar(20),

deptno int,

salary int

)engine=innodb default charset=utf8

INSERT INTO hr VALUES(1,"zhangsan",1,2000);

INSERT INTO hr VALUES(2,"lisi",1,2100);

INSERT INTO hr VALUES(3,"小明",2,2500);

INSERT INTO hr VALUES(4,"小红",2,2200);

INSERT INTO hr VALUES(5,"小王",3,1800);

INSERT INTO hr VALUES(6,"小陈",3,1900);

INSERT INTO hr VALUES(7,"小赵",3,3000)

#写一个存储过程,统计部门员工人数

DELIMITER $$

CREATE PROCEDURE proce1(IN dno INT,OUT total_number INT)

BEGIN

SELECT COUNT(id) INTO total_number FROM hr WHERE deptno=dno;

END$$

DELIMITER

#调用存储过程

#测试1部门的员工人数

CALL proce1(1,@test)

SELECT @test AS 人数

SELECT @test

#验证2部门的员工人数

CALL proce1(2,@renshu)

SELECT @renshu AS 人数

#验证3部门的员工人数

CALL proce1(3,@test)

SELECT @test

#验证一个不存在的部门的员工人数

CALL proce1(4,@test)

SELECT @test

#查看数据库中所有的存储过程

SHOW PROCEDURE STATUS

#查看具体某一个存储过程

SHOW CREATE PROCEDURE proce1

#删除一个存储过程

DROP PROCEDURE pro;

DROP PROCEDURE pro1;

DROP PROCEDURE pro2

mysql:用户管理、索引、视图、函数、存储过程的更多相关文章

  1. MySQL用户管理及权限设置

    mysql 用户管理和权限设置 用户管理 mysql>use mysql; 查看 mysql> select host,user,password from user ; 创建 mysql ...

  2. Mysql用户管理及权限分配

    早上到公司,在服务器上Mysql的数据库里新建了个database,然后本地的系统里用原来连接Mysql账号admin连这个数据库.结果报错了,大概是这样子的: Access denied for u ...

  3. MySQL用户管理及SQL语句详解

    1.1 MySQL用户管理 1.1.1 用户的定义 用户名+主机域 mysql> select user,host,password from mysql.user; +--------+--- ...

  4. 【转】MySQL用户管理及SQL语句详解

    [转]MySQL用户管理及SQL语句详解 1.1 MySQL用户管理 1.1.1 用户的定义 用户名+主机域 mysql> select user,host,password from mysq ...

  5. MySQL(十六)之MySQL用户管理

    一.MySQL用户管理概述 MySQL是一个多用户的数据库,MYSQL的用户可以分为两大类: 超级管理员用户(root),拥有全部权限 普通用户,由root创建,普通用户只拥有root所分配的权限 二 ...

  6. 库增删该查,表增删该查,记录增删该查,表与表关系(多对多,多对一,一对一),mysql用户管理

    库增删该查 增加库 create database db1 create database db1 charset="gbk 查看库 show databases 查看所有库 show cr ...

  7. MySQL用户管理、常用sql语句、MySQL数据库备份恢复

    1.MySQL用户管理 给远程登陆用户授权:grant all on *.* to 'user1'@'127.0.0.1' identified by '123456' (这里的127.0.0.1是指 ...

  8. MySQL 用户管理与权限管理

    MySQL 用户管理与权限管理 -- 操作环境mysql> show variables like 'version';  +---------------+--------+| Variabl ...

  9. Python 42 mysql用户管理 、pymysql模块

    一:mysql用户管理 什么是mysql用户管理 mysql是一个tcp服务器,应用于操作服务器上的文件数据,接收用户端发送的指令,接收指令时需要考虑到安全问题, ATM购物车中的用户认证和mysql ...

  10. Linux centosVMware mysql用户管理、常用sql语句、mysql数据库备份恢复

    一.mysql用户管理 grant all on *.* to 'user1'@‘127.0.0.1’ identified by 'mimA123'; 创建user1用户 使用user1登录 /us ...

随机推荐

  1. P1567 统计天数

    题目背景 统计天数 题目描述 炎热的夏日,KC非常的不爽.他宁可忍受北极的寒冷,也不愿忍受厦门的夏天.最近,他开始研究天气的变化.他希望用研究的结果预测未来的天气. 经历千辛万苦,他收集了连续N(1& ...

  2. 2018.9.7 ArrayList

    ArrayList简介 ArrayList核心源码 ArrayList源码分析 System.arraycopy()和Arrays.copyOf()方法 两者联系与区别 ArrayList核心扩容技术 ...

  3. 2017.9.23 HTML学习总结----JavaScript实现输入验证

    定义:对于一个HTML页面中的表单,可以获取其中的各项表单域信息, 利用这些信息,可以判定个表单域所提供的输入值是否合法,是否 符合所要求的格式,这就是表单的输入验证. (1)需要验证的表单输入域的要 ...

  4. EF 状态版 增删改

    1.利用 状态版 实现 增加 . 2.利用状态版 进行 删除 3. 利用状态版 实现 修改 ,修改 方法 有3种 第1种修改方法 第2种修改 方法 第3种修改方法

  5. MapReduce计算每年最大值测试样例生成程序

    Demo.java package com.java; import java.io.BufferedWriter; import java.io.File; import java.io.FileW ...

  6. LeetCode(Two Sum)

    一.题目要求 Given an array of integers, return indices of the two numbers such that they add up to a spec ...

  7. 【书籍连载】《STM32 HAL 库开发实战指南—基于F7》-第一章

    从今天起,每天开始连载一章<STM32 HAL 库开发实战指南—基于F7>.欢迎各位阅读.点评.学习. 第1章  如何使用本书 1.1  本书的参考资料 本书参考资料为:<STM32 ...

  8. 史上最简单的SpringCloud教程 | 第八篇: 消息总线(Spring Cloud Bus)

    转载请标明出处: 原文首发于:https://www.fangzhipeng.com/springcloud/2017/07/12/sc08-bus/ 本文出自方志朋的博客 最新Finchley版本请 ...

  9. SqlServer 连接GreenPlum问题处理

    一.SQL SERVER.GREENPLUM 1. SSIS安装 ▶ 安装SQL SERVER 2005 数据库之后,运行SSIS工具,建立包,建立完成之后,新建工作流,双击工作流之后无法进行编辑,并 ...

  10. java基础必备单词讲解 day three

    if 如果 else 否则 switch 切换判断 case 实例 break 退出 return 返回 default 默认 variable array 数组 null 空的 无效的 pointe ...