当前位置: 首页 > news >正文

网站建设合作加盟郑州seo软件

网站建设合作加盟,郑州seo软件,网站设计的初衷,网站空间配置函数函数是什么?多用于查询语句,实现了某种功能;用途与存储过程不同,但语法是类似的;函数语法create function 函数名([参数列表]) returns 数据类型 begin DECLARE 变量; sql 语句; return 值; end; 设置函…

函数


函数是什么?

多用于查询语句,实现了某种功能;用途与存储过程不同,但语法是类似的;

函数语法

create function 函数名([参数列表]) returns 数据类型

begin

DECLARE 变量;

sql 语句;

return 值;

end;

设置函数可以没有参数

需要单独执行一次,必须设置为true,否则函数就创建不成功。

SET GLOBAL log_bin_trust_function_creators=TRUE;

删除函数

FROP Function 函数名;

注:测试函数时可以使用dual,如下:
select new_count() from dual;
dual是一个虚拟表,一般用于实现查询结构;

以下是一些举例:

SET GLOBAL log_bin_trust_function_creators=TRUE; 
-- 创建函数 不带参数
​
DELIMITER $$
​
CREATE FUNCTION `gradedb`.`admin_count`() RETURNS INT
​BEGINDECLARE admin_num INT DEFAULT 0;SELECTCOUNT(*) INTO admin_num FROM admin;RETURN admin_num;END$$
DELIMITER ;
​
-- 测试函数
SELECT admin_count();
SELECT admin_count() FROM DUAL;  -- dual是虚拟表,用来完善查询结构
​
​
-- 删除函数
DROP FUNCTION admin_count();
​
​
​
-- 有参函数  通过admin id找到admin account
DELIMITER $$
​
CREATE FUNCTION `gradedb`.`findAdminById`(admin_id INT) RETURNS VARCHAR(10)
​BEGINDECLARE a_account VARCHAR(10) ;SELECT account INTO  a_account FROM admin WHERE admin.`id`=admin_id;RETURN a_account;END$$
​
DELIMITER ;
​
​
-- 有参函数 课程转化,通过课程id转化成课程名称
DELIMITER $$
​
CREATE FUNCTION `gradedb`.`class_turn`(class_id INT) RETURNS VARCHAR(10)
​BEGINDECLARE classname VARCHAR(10);SELECT NAME INTO classname FROM class WHERE id = class_id;RETURN classname;END$$
DELIMITER ;
-- 测试函数
SELECT id,class_turn(1) FROM class WHERE id=1; 

触发器


是一种特殊的存储过程,不需要用户直接调用,而是在对表增加,修改,删除,没有查询,操作之前或之后触发自动执行的存储过程。

触发器的特点:

1.与表相关联

触发器定义在特定的表上,这个表称为触发器表。

2.自动激活触发器

当对表中的数据执行 INSERT、UPDATE 或 DELETE 操作时,如果对表上的这个特定操作定义了触发器,该触发器自动执行,这是不可撤销的。

3.不能直接调用

与存储过程不同,触发器不能被直接调用,也不能传递或接受参数。

4.作为事务的一部分

触发器与激活触发器的语句一起做为对一个单一的事务来对待,可以从触发器中的任何位置回滚。

触发器是行级触发 FOR EACH ROW -- 行级触发 ,就是每操作表中的一行数据,就会调用一次触发器

在创建触发器时,可以通过old和new调用你想要的数据:
old可以表示删除操作时你要删除的那一条数据,以及修改操作中修改前的数据;
new可以表示你增加操作时,新加入的那一条数据;以及修改操作后的数据;

触发器的语法:

CREATE TRIGGER 触发器名称 触发时机 触发事件

ON 表名称

FOR EACH ROW -- 设置行级触发

BEGIN

语句

END;

触发时机指before和after

触发事件:包括insert、delete、update

举例:

-- 创建触发器   删除student ,需要删除他与所选课程的关系
DELIMITER $$
CREATE TRIGGER `gradedb`.`delete_student_class` BEFORE DELETEON `gradedb`.`student` FOR EACH ROW -- 行级触发,每对表中的一行数据进行操作,就会触发一次触发器BEGINDELETEFROM student_class WHERE studentid=old.id;END$$
DELIMITER ;
​
-- 测试触发器
DELETEFROM student WHERE id=7;
​
​
​
-- 创建触发器 新增用户时,需要向其他表插入数据
DELIMITER $$
CREATE TRIGGER `gradedb`.`insert_student_class` AFTER INSERT
ON `gradedb`.`student` 
FOR EACH ROW -- 行级触发,每对表中的一行数据进行操作,就会触发一次触发器
BEGIN
INSERTINTO student_class(studentid,classid,grade) VALUE(new.id,1,1);
END $$
DELIMITER;
​
-- 测试触发器
INSERTINTO student(account,NAME) VALUE(777,"小明") 

http://www.yidumall.com/news/21858.html

相关文章:

  • 哈尔滨网站制作哪家好薇山东建站管理系统
  • 美食网站的建设免费网站推广平台
  • 网站做抽奖活动做网站用什么编程软件
  • 广州有哪些做网站专业的公司seo单页面优化
  • 网站建设实验总结百科上海搜索优化推广哪家强
  • 石家庄h5网站建设手机建站教程
  • com域名的网站网络优化工程师主要做什么
  • 奉化住房和城乡建设委员会网站搜索引擎网站入口
  • 新氧网站头图怎么做的网站seo优化排名
  • seo教程自学网谷歌seo建站
  • 做微课常用的网站怎么做关键词排名靠前
  • 如何快速做h5网站百度竞价关键词质量度怎么提升
  • 营销型网站的建设要求都有什么职业培训机构哪家最好
  • 网站建立之间不安全如何解决百度搜索广告价格
  • 物流如何做网站微信广告投放推广平台多少费用
  • 如何建设互联网政务门户网站直播营销策划方案范文
  • 建设品牌网站制作网页一般多少钱
  • 泉州微信网站开发公司专业网站优化公司
  • 建设银行个人官方网站免费网站推广优化
  • 河北省建设厅网站刷身份证流程百度搜索关键词规则
  • 网站开发可以入无形资产吗怎样做自己的网站
  • iis内网站设置允许脚本执行b站推广是什么意思
  • .网站建设的基本步骤沈阳seo搜索引擎
  • 相亲网站的女人 做直播的怎么发帖子做推广
  • 网站开发维护多少钱网站权重一般有几个等级
  • 幼儿园网站的建设需求分析广告设计网站
  • 北京网站建设q.479185700強it培训学校it培训机构
  • 如何建设平台型的网站网站设计制作
  • 辽宁省建设机械协会官方网站东莞网站制作的公司
  • 网站开发成本预算快速推广