SQL语句之 知识补充
SQL语句之 知识补充
一.存储过程
运用SQL语句,写出一个像函数的模块,这就是存储过程。
需求: 编写存储过程,查询所有员工 -- 创建存储过程(必须要指定结束符号) -- 定义结束符号 DELIMITER $ CREATE PROCEDURE pro_test() BEGIN SELECT * FROM student; END $ CALL pro_test -- 调用存储过程 创建存储语句: delimiter 结束符号 create procedure 存储过程名称( 参数列表 out value varchar(20))//利用系统变量输出数据 begin -- 开始 sql语句1 sql语句2 end 结束符号 调用存储过程语法: call 存储过程名称(参数,@value); Select @value; 参数类型: IN : 输入参数,把参数带入存储过程 OUT: 输出参数,把结果随着参数带出到外面 INOUT: 输入输出。 输入+输出 |
二.触发器
触发器
在数据库服务器中执行了某些操作之后,希望触发一些事件、动作。就可以使用触发器
触发器案例
需求 : 当往employee表插入一条数据时,把该插入数据的动作记录到另一张表 logs
解决办法:编写一个触发器,监听employee表的数据插入。
-- *********四、 触发器*********** -- 创建日志表 CREATE TABLE tri_logs( content VARCHAR(100) ) -- 创建添加触发器 触发器的名字 操作 创建在哪个表 CREATE TRIGGER tri_addEmp AFTER INSERT ON employee FOR EACH ROW -- 往employee表插入一条记录时 INSERT INTO tri_logs(content) VALUES('用户往employee表插入记录'); 触发后的操作 -- 创建修改触发器 CREATE TRIGGER tri_updEmp AFTER UPDATE ON employee FOR EACH ROW INSERT INTO tri_logs(content) VALUES('用户修改了employee表记录'); -- 创建删除触发器 CREATE TRIGGER tri_delEmp AFTER DELETE ON employee FOR EACH ROW INSERT INTO tri_logs(content) VALUES('用户删除了employee表记录'); -- 往员工表插入数据 INSERT INTO employee(ename, deptId) VALUES('eric',4); -- 修改 UPDATE employee SET ename='jacky' WHERE eid=7; -- 删除 DELETE FROM employee WHERE eid=7; -- 查询 SELECT * FROM employee; SELECT * FROM tri_logs; |
MySQL数据库备份和还原
备份语句: mysqldump -u root -p day17 > c:/bak.sql 执行次命令不需要登录
还原语句: mysql -u root -p day17 < d:/back.sql
MySQL数据库权限问题
-- ********** 五、 MySQL数据库权限问题 **** -- 安装mysql的时候,使用默认用户root,root是超级管理员,拥有对数据库的所有权限。(为了学习) -- 实际应用中,会有数据库角色配置。例如张三只能查看数据,李四只能创建表,不能删除表。 -- 目标: 根据不同角色给不同用户分配数据库操作权限 -- 修改用户的密码 -- mysql数据库是存储mysql数据库软件用户信息 USE mysql; SHOW TABLES; -- 查询mysql.user表 SELECT * FROM USER; -- 密码加密函数 SELECT PASSWORD('root'); -- *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B -- 修改root密码 UPDATE USER SET PASSWORD=PASSWORD('123456') WHERE USER='root'; -- 给用户分配权限 GRANT SELECT ON day16.employee TO 'eric'@'localhost' IDENTIFIED BY '123456'; GRANT SELECT ON day16.dept TO 'eric'@'localhost' IDENTIFIED BY '123456'; |
SQL语句之 知识补充的更多相关文章
- [20190329]探究sql语句相关mutexes补充2.txt
[20190329]探究sql语句相关mutexes补充2.txt --//昨天测试sql语句相关mutexes,看看如果出现多个子光标的情况. 1.环境:SCOTT@book> @ ver1P ...
- SQL语句基础知识
1.关于SQL语句中exists与not exists的问题 course表如下:课程代号 课程名称 K01 奥运会主题曲 K02 喜爱的专辑 K03 VB技术大全 K04 经典歌曲 K05 个人单曲 ...
- 工作中常用的sql语句以及知识整理
一.常用的sql语句 1.建表语句 create table tabname(colname1 type1 [not null][primary key], colname2 type2,...) 根 ...
- Django中执行原生SQL语句【新编辑】
参考我的个人博客 这部分迁移到了个人博客中:Django中执行原生SQL语句 这里需要补充一下,还有一个extra方法: ret = models.Student.objects.all().extr ...
- MySQL之唯一索引、外键的变种、SQL语句数据行操作补充
0.唯一索引 unique对num进行唯一限制,表示num是独一无二的,uql是唯一索引名称 上面为联合索引:num和xx不能完全一样 1.外键的变种 a. 用户表和部门表 用户: 1 alex 1 ...
- 面试、笔试中常用的SQL语句(数据库知识必杀)一共50个!!!
Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,Tname) 教师表 ...
- 跟踪oracle中sql语句运行过程及相关知识拓展
select * from v$sqlarea; select * from v$sqlarea where first_load_time>'2010-11-27/09:30:00'; 这种方 ...
- 常见SQL语句和SQL基础知识
引自:http://blog.csdn.net/u012467492/article/details/46790205 SQL语句考察(一) 1.查询出每门课都大于80 分的学生姓名 name k ...
- 数据库基础知识详解四:存储过程、视图、游标、SQL语句优化以及索引
写在文章前:本系列文章用于博主自己归纳复习一些基础知识,同时也分享给可能需要的人,因为水平有限,肯定存在诸多不足以及技术性错误,请大佬们及时指正. 11.存储过程 存储过程是事先经过编译并存储在数 ...
随机推荐
- 博皮设计:HTML/CSS/Javascript 源码共享
首先感谢 sevennight 对我的大力帮助,由此他也成为了我的第一位园友:其次,由于本人并不了解 HTML/CSS,因此几乎都在 李宝亨 设计的 博皮源码 的基础上进行的修改:最后,为了获得 更加 ...
- MySQL练习-主外键多表查询
练习: 1.建立表关系: 请创建如下表,并创建相关约束 USE db1; CREATE TABLE class( cid INT AUTO_INCREMENT PRIMARY KEY, caption ...
- python模块-logging的智商上限
logging,故名肆意就是正在进行日志,我艹,这个文化底蕴! logging是python内置的日志模块,便于日常程序的日志写入和输出 logging共分为5个日志等级,分别是: debug , i ...
- 20165230 《Java程序设计》实验一(Java开发环境的熟悉)实验报告
20165230 <Java程序设计>实验一(Java开发环境的熟悉)实验报告 一.实验报告封面 课程:Java程序设计 班级:1652班 姓名:田坤烨 学号:20165230 成绩: 指 ...
- 一个diff工具,用于判断两个目录下所有的改动(比较新旧版本文件夹)
需求: 编写一个diff工具,用于判断两个目录下所有的改动 详细介绍: 有A和B两个目录,目录所在位置及层级均不确定 需要以B为基准找出两个目录中所有有改动的文件(文件或内容增加.修改.删除),将有改 ...
- 再战CS231-快速排序
1.用python实现快速排序 print quicksort([3,6,8,10,1,2,1]) # Prints "[1, 1, 2, 3, 6, 8, 10]" ''' @a ...
- js原生选择class DOM元素
document.querySelector(".demo"); querySelector() 方法返回匹配指定选择器的第一个元素.如果需要返回所有的元素,使用 querySel ...
- wordcount在本地运行报错解决:Exception in thread "main" java.lang.UnsatisfiedLinkError:org.apache.hadoop.io.native.NativeID$Windows.access
在windows中的intellij中运行wordcount程序,控制台输出以下报错 在Intellij编辑器中解决办法:本地重新创建NativeIO类,修改一个方法返回值,然后用新建的NativeI ...
- style一张图--openlayers
- 洛谷P2261余数求和
传送门啦 再一次见证了分块的神奇用法,在数论里用分块思想. 我们要求 $ ans = \sum\limits ^{n} _{i=1} (k % i) $ ,如果我没看错,这个题的暴力有 $ 60 $ ...