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

江阴建设网站制作营销网页

江阴建设网站,制作营销网页,网站底部怎么做,js特效网站模板下载2023.9.21 函数 含义:一组预先编译好的SQL语句的集合,理解成批处理语句。 提高代码的重用性简化操作减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率 与存储过程的区别: 存储过程:可以有0个返回&am…

2023.9.21

函数

含义:一组预先编译好的SQL语句的集合,理解成批处理语句。

  1. 提高代码的重用性
  2. 简化操作
  3. 减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

与存储过程的区别:

存储过程:可以有0个返回,也可以有多个返回,适合做批量插入、批量更新。
函数:有且仅有1 个返回,适合做处理数据后返回一个结果。

下面是函数相关学习笔记:

#一、创建语法
CREATE FUNCTION 函数名(参数列表) RETURNS 返回类型
BEGIN函数体
END
/*注意:
1.参数列表 包含两部分:
参数名 参数类型2.函数体:肯定会有return语句,如果没有会报错
如果return语句没有放在函数体的最后也不报错,但不建议return 值;
3.函数体中仅有一句话,则可以省略begin end
4.使用 delimiter语句设置结束标记*/#二、调用语法
SELECT 函数名(参数列表)#------------------------------案例演示----------------------------
#1.无参有返回
#案例:返回公司的员工个数
CREATE FUNCTION myf1() RETURNS INT
BEGINDECLARE c INT DEFAULT 0;#定义局部变量SELECT COUNT(*) INTO c#赋值FROM employees;RETURN c;END $SELECT myf1()$#2.有参有返回
#案例1:根据员工名,返回它的工资CREATE FUNCTION myf2(empName VARCHAR(20)) RETURNS DOUBLE
BEGINSET @sal=0;#定义用户变量 SELECT salary INTO @sal   #赋值FROM employeesWHERE last_name = empName;RETURN @sal;
END $SELECT myf2('k_ing') $#案例2:根据部门名,返回该部门的平均工资CREATE FUNCTION myf3(deptName VARCHAR(20)) RETURNS DOUBLE
BEGINDECLARE sal DOUBLE ;SELECT AVG(salary) INTO salFROM employees eJOIN departments d ON e.department_id = d.department_idWHERE d.department_name=deptName;RETURN sal;
END $SELECT myf3('IT')$#三、查看函数SHOW CREATE FUNCTION myf3;#四、删除函数
DROP FUNCTION myf3;#案例
#一、创建函数,实现传入两个float,返回二者之和CREATE FUNCTION test_fun1(num1 FLOAT,num2 FLOAT) RETURNS FLOAT
BEGINDECLARE SUM FLOAT DEFAULT 0;SET SUM=num1+num2;RETURN SUM;
END $SELECT test_fun1(1,2)$

 流程控制

        流程控制分为顺序、分支、循环。

下面为三种流程控制相关学习笔记:

#一、分支结构
#1.if函数
/*
语法:if(条件,值1,值2)
功能:实现双分支
应用在begin end中或外面*/#2.case结构
/*
语法:
情况1:类似于switch
case 变量或表达式
when 值1 then 语句1;
when 值2 then 语句2;
...
else 语句n;
end 情况2:
case 
when 条件1 then 语句1;
when 条件2 then 语句2;
...
else 语句n;
end 应用在begin end 中或外面*/#3.if结构/*
语法:
if 条件1 then 语句1;
elseif 条件2 then 语句2;
....
else 语句n;
end if;
功能:类似于多重if只能应用在begin end 中*/#案例1:创建函数,实现传入成绩,如果成绩>90,返回A,如果成绩>80,返回B,如果成绩>60,返回C,否则返回DCREATE FUNCTION test_if(score FLOAT) RETURNS CHAR
BEGINDECLARE ch CHAR DEFAULT 'A';IF score>90 THEN SET ch='A';ELSEIF score>80 THEN SET ch='B';ELSEIF score>60 THEN SET ch='C';ELSE SET ch='D';END IF;RETURN ch;END $SELECT test_if(87)$#案例2:创建存储过程,如果工资<2000,则删除,如果5000>工资>2000,则涨工资1000,否则涨工资500CREATE PROCEDURE test_if_pro(IN sal DOUBLE)
BEGINIF sal<2000 THEN DELETE FROM employees WHERE employees.salary=sal;ELSEIF sal>=2000 AND sal<5000 THEN UPDATE employees SET salary=salary+1000 WHERE employees.`salary`=sal;ELSE UPDATE employees SET salary=salary+500 WHERE employees.`salary`=sal;END IF;END $CALL test_if_pro(2100)$#案例1:创建函数,实现传入成绩,如果成绩>90,返回A,如果成绩>80,返回B,如果成绩>60,返回C,否则返回DCREATE FUNCTION test_case(score FLOAT) RETURNS CHAR
BEGIN DECLARE ch CHAR DEFAULT 'A';CASE WHEN score>90 THEN SET ch='A';WHEN score>80 THEN SET ch='B';WHEN score>60 THEN SET ch='C';ELSE SET ch='D';END CASE;RETURN ch;
END $SELECT test_case(56)$#二、循环结构
/*
分类:
while、loop、repeat循环控制:iterate类似于 continue,继续,结束本次循环,继续下一次
leave 类似于  break,跳出,结束当前所在的循环*/#1.while
/*语法:【标签:】while 循环条件 do循环体;
end while【 标签】;联想:while(循环条件){循环体;
}*/#2.loop
/*语法:
【标签:】loop循环体;
end loop 【标签】;可以用来模拟简单的死循环*/#3.repeat
/*
语法:
【标签:】repeat循环体;
until 结束循环的条件
end repeat 【标签】;*/#1.没有添加循环控制语句
#案例:批量插入,根据次数插入到admin表中多条记录
DROP PROCEDURE pro_while1$
CREATE PROCEDURE pro_while1(IN insertCount INT)
BEGINDECLARE i INT DEFAULT 1;WHILE i<=insertCount DOINSERT INTO admin(username,`password`) VALUES(CONCAT('Rose',i),'666');SET i=i+1;END WHILE;END $CALL pro_while1(100)$/*int i=1;
while(i<=insertcount){//插入i++;}*/#2.添加leave语句#案例:批量插入,根据次数插入到admin表中多条记录,如果次数>20则停止
TRUNCATE TABLE admin$
DROP PROCEDURE test_while1$
CREATE PROCEDURE test_while1(IN insertCount INT)
BEGINDECLARE i INT DEFAULT 1;a:WHILE i<=insertCount DOINSERT INTO admin(username,`password`) VALUES(CONCAT('xiaohua',i),'0000');IF i>=20 THEN LEAVE a;END IF;SET i=i+1;END WHILE a;
END $CALL test_while1(100)$#3.添加iterate语句#案例:批量插入,根据次数插入到admin表中多条记录,只插入偶数次
TRUNCATE TABLE admin$
DROP PROCEDURE test_while1$
CREATE PROCEDURE test_while1(IN insertCount INT)
BEGINDECLARE i INT DEFAULT 0;a:WHILE i<=insertCount DOSET i=i+1;IF MOD(i,2)!=0 THEN ITERATE a;END IF;INSERT INTO admin(username,`password`) VALUES(CONCAT('xiaohua',i),'0000');END WHILE a;
END $CALL test_while1(100)$/*int i=0;
while(i<=insertCount){i++;if(i%2==0){continue;}插入}*/

http://www.yayakq.cn/news/938604/

相关文章:

  • 郑州网站关键词优化公司哪家好wordpress提交文章
  • 怎么看一个网站做外链wordpress添加默认头像
  • 网站开发的方法专业零基础网站建设教学在哪里
  • 厦门营销型网站建设什么是网站组件
  • 网站建设金手指海外网站seo
  • ks2e做网站表白网页制作模板
  • 网站做任务挣钱网页设计与制作实验报告总结
  • 虚拟主机网站后台一线全屋定制10大品牌
  • 一般做网站所使用的字体苏州公司建设网站首页
  • cms 企业网站管理系统wordpress模版全屏
  • 深圳app网站建设哪家好好听的网络科技公司名字
  • 网站不足做暧暧小视频免费网站
  • 太原模板网站建站免费晋江网站建设
  • 北京网站优化怎么样网站排名优化推广公司
  • 网站建设公司企业网站旬阳做网站
  • 淄博网站优化莱芜金点子最新消息
  • 河南制作网站公司影视网站怎么建设
  • 抖音代运营业务介绍免费seo软件
  • 成都门户网站建网站设置网站首页
  • 贵阳网站建设技术支持html网页模板下载html模板
  • 旅游网站建设方案简介网站开发checklist
  • 分类信息网站手机版成都二次感染最新消息
  • 电子商务网站开发的流程wordpress页面内
  • 上线公司 企业网站网站专题页面
  • 郑州网站建设网站制作wordpress 编辑
  • 做生产计划类的网站wordpress的中文插件安装教程视频
  • 网站建设zphp怎么做多个网站
  • 什么是网站开发与建设前端用什么软件开发
  • 织梦网站系统删除不了如何做好市场推广
  • 福州做网站公司网站服务器到期查询