mysql createst_mysql 自定义函数

参考文章地址是:

因为工作需要,要写一个mysql的自定义行数,如下

DELIMITER $$

DROP FUNCTION IF EXISTS `onlineFunction`$$

CREATE FUNCTION `onlineFunction`(rrrr VARCHAR(50)) RETURNS VARCHAR(255)

BEGIN

IF(rrrr='online') THEN RETURN '上线';END IF;

END$$

DELIMITER ;

第一行DELIMITER定义一个结束标识符,因为MySQL默认是以分号作为SQL语句的结束符的,而函数体内部要用到分号,所以会跟默认的SQL结束符发生冲突,所以需要先定义一个其他的符号作为SQL的结束符。没有加这个定义的话...

错误码: 1064

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'end' at line 1

第二行是删除同名的类,不然会...

错误码: 1304

FUNCTION onlineFunction already exists

第三行第一函数名,函数变量,和返回类型

第四行begin是起始,与end$$对应

第五行是if判断语句,格式为

if(...) then

....;

elseif

....;

else

.....;

end if;

return ..;

有时候mysql不能建立自定义函数是因为该功能2未开启

输入show variables like '%func%'; 命令

会看到 log_bin_trust_function_creators的状态,如果是OFF表示自定义函数功能是关闭的

输入命令set globallog_bin_trust_function_creators=1;

可将log_bin_trust_function_creators 开启自定义函数功能

但是这样设置是一个临时的方案,因为mysql自动重启后状态又会变为OFF,所以需要在

在服务启动时加上 “--log-bin-trust-function-creators=1 ”参数。

或在my.ini(my.cnf)中的[mysqld]区段中加上 log-bin-trust-function-creators=1。

将//单选题模拟数据 var ch = new Array(); //第一步:取出localstorage里面的单选题字符串str //第二步:用split方法切割str,用*号切割,切割后生成了一个字符串数组a //第三步:遍历数组a,将数组的每一个元素格式化成对象后放到ch里面 ch[0] = {     title: '花生播种前常要松土的主要原因是种子萌发需要(  )',     a: '充足的空气',     b: '适宜的温度',     c: '适量的水分',     d: '一定的光照',     answer: 'a',     score: 20 }; //p是卷子 var p = creaTest(); //组卷 function creaTest() {     var test = getProblem(ch,5);     return test; } //抽题 //list为题型数组,num为要取出的题目的数量 // function getProblem(list,num) {     var pro = [];     var randomIndexe = [];     var index;     var i = 0;     do{         //         //         index = parseInt(list.length * Math.random());         //         //         if (randomIndexe.indexOf(index) === -1) {             randomIndexe.push(index);             pro.push(list[index]);             i++;         }     } while (i < num)     return pro; } //keys是答案数组 var keys = getKeys(); //创建答案数组 function getKeys() {     var array = new Array(p.length);//当前试卷的正确答案     for (var i = 0; i< p.length; i++) {         array[i] = p[i].answer;     }     return array; },的ch里面的单选题模拟数据换成从localstorage里面取出来的数据
06-07
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值