今天测试“审批流撤销”功能,突然遇到一个奇怪的问题:日志显示新增数据成功,db里却查不到。
代码如下:
try{
$service_document->retreat($workflow_type_id, $doc_manage_id);
$this->requestSuccessResponse();
}catch(\Exception $e){
$service_log = new LogService();
$service_log->createLog($doc_manage_id, LabelService::TEXT_LOG_CATEGORY_DOCUMENT, $e->getMessage());
$this->requestErrorResponse("retreat fail");
}
createLog是添加日志记录的方法。测试功能,提示了retreat fail,但是数据库日志表里却看不到数据。
新增日志的方法,打印出sql以及新增之后的主键ID,都是没问题的。
问题出在Service里retreat方法上。先上代码:
$res3 = $obj_model->table('tms_new_workflow_process')
->where(array('workflow_type_id' => $type, 'subject_id'=> $doc_manage_id))
->save($process_update);
if(false === $res3){
$obj_model->rollback();
throw new Exception("update workflow process fail!");
}
$obj_model->commit();
$("#list_language_file").html(htmlLanguageFile);
$('#mainTab').tabs('add',{
width:$("#mainTab").parent().width() - 180,
title: " Document Detail-" + dataCellClick.doc_name,
iconCls: null,
href: 'Document/documentDetail?doc_manage_id='+dataCellClick.doc_manage_id,
closable: true
});
在这篇文章:
laravel 中用group by和order by排序不正确的问题解决
中,提出了如下知识点:
mysql中order by是在group by之后执行的,而group by则是在同一组数据里挑选出id最小的数据记录作为汇总记录
以前的经验,是先在order by的子查询末尾加上:
limit 1000
结果今天发现它不生效。
相关表sql:
CREATE TABLE `tms_doc_manage` ( `doc_manage_id` INT(11) NOT NULL AUTO_INCREMENT, `doc_main_id` INT(11) NOT NULL COMMENT 'doc主表id', `section_id` INT(11) NOT NULL DEFAULT '1' COMMENT 'section id', `modify_times` TINYINT(2) NOT NULL DEFAULT '0' COMMENT '文件修改次数', `status` TINYINT(2) NOT NULL DEFAULT '1' COMMENT '0-delete 1-inactive 2-new 3-submitted 4-processing 5-approve 6-reject', `creator_id` INT(11) NULL DEFAULT NULL, `create_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, `updater_id` INT(11) NULL DEFAULT NULL, `update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (`doc_manage_id`) ) COMMENT='文档管理表' COLLATE='utf8_general_ci' ENGINE=InnoDB AUTO_INCREMENT=0 ;
这周给服务器安装环境,其中一部分是安装神通数据库。由于网上有关神通数据库的资料实在是不多,踩了不少坑,本文现将安装的详细过程及其中遇到的坑记录下来。
开发环境是Windows系统,有安装神通对应的软件工具,其中“DBA管理工具”软件就可以对数据库进行逻辑备份,将数据库导出成osr后缀的文件。
此次要安装环境的服务器主板是龙芯主板(loongson),神通数据库有对应的源码,可自行下载:各个类型版本的神通数据库下载
下载安装包(假定是shentong.tar.gz),解压后,开始进行安装(假定解压在/opt/shentong目录下)。
修改/opt/shentong/Disk1/InstData/st.propertities文件,将OSRDB全部替换成我们要建的数据库名,例如BLUEZHAI。
:s/OSRDB/BLUEZHAI/g
查了许久资料,也尝试了许久时间,没能找到什么时候可以自行用命令创建数据库,所以只好将默认数据库直接改成我想要的数据库。
要建多个库的话,我这种方式就行不通了。
最近工作中有一些关于swoole的问题解决不了,所以打算系统的学习一下swoole。
刚开始第一步创建服务端和客户端,就遇到客户端程序始终连不上服务端的问题。
起初报如下错误:
PHP Fatal error: Swoole\Client::__construct(): please install the ext-async extension, using Swoole\Async\Client in /opt/study/client.php on line 3
这是因为程序创建的客户端,用了异步参数,而且代码是swoole4.4版本的,说是在swoole4.5版本下异步客户端创建方式有调整,具体调整啥,暂且不管了,先就直接用同步参数了。
$client = new Swoole\Client(SWOOLE_SOCK_TCP);
swoole tcp服务端程序如下:
$serv = new Swoole\Server("127.0.0.1", 6400); $serv->set([ 'work_num' => 2 ]); //监听连接进入事件 $serv->on('Connect', function ($serv, $fd) { echo "Client: Connect.\n"; });
昨天在php-7.2.32环境下,编译安装swoole-4.5.3版本的扩展,尝试重新编译php和swoole好几次,都是报undefined symbol: sapi_globals的错误,整体错误信息如下:
Starting php-fpm [08-Sep-2020 22:12:16] NOTICE: PHP message: PHP Warning: PHP Startup: Unable to load dynamic library 'swoole.so' (tried: /opt/software/somodules/swoole.so (/opt/software/somodules/swoole.so: undefined symbol: sapi_globals), /opt/software/somodules/swoole.so.so (/opt/software/somodules/swoole.so.so: cannot open shared object file: No such file or directory)) in Unknown on line 0
为了让自己的博客文章有更好的阅读体验,昨晚翟码农给博客文章添加了目录导引。
现主要记录下其思想,本文代码为jQuery框架下的,使用vue框架的,或者给博客园、wordpress博客文章添加目录的,原理都相似,对代码稍稍调整即可。
要实现文章目录索引效果,主要实现以下3个任务:
1.假定博客里标题固定为h3、h4格式,先将这些标题内容获取出来,生成目录。
2.点击目录链接,文章滚动到指定位置。
3.滚动文章,对应目录的链接样式能高亮显示
如果想直接看全部代码的,就直接拉到文章末尾。实现效果,尝试点击本文章里目录或者滚滚文章试试吧。
用jQuery实现也很简单,用如下一行代码就可以获取文章里所有用h3和h4格式的标题。
let titles = document.querySelectorAll(".box-content h3,h4");
.box-content是翟码农博客文章div的class,大家根据自己实际情况修改即可。
在文章页面添加好如下div,用来展示目录:
文章大纲
再遍历上面获取的标题,将其塞进上面目录div里。
titles.forEach((element, index) => { var linkItem = document.createElement('a'); linkItem.innerHTML = element.innerHTML; linkItem.setAttribute('id', 'anchor_'+index); linkItem.setAttribute('class', 'link-index'); linkItem.href = 'javascript:void(0)'; indexBoxItem.append(linkItem); });
天色将晚,我出门看了看镜子,忽然感觉是时候要剪个头发了。要说今天与往常有什么不同,不过是晚上将见一个朋友罢了——男的。
暑气阑珊,走在昏黄路灯的街上,呼吸着树林间微风鼓动的气息,仿佛此时此刻才是生活的味道。
理发店离酒店很近,走个七八百米就到了。
门口的白色荧光灯在飞速的转动,我一推开门就朝迎面走来的人说道:“老板,理发多少钱?”
“有38块,也有68块的,看你要剪哪样?”他微笑的回答着我,那笑容看不出一点做作。
“有什么区别么?都是洗剪吹?”
“嗯——没什么区别,只是剪发的人不同”,他继续解释着,“嗯,都是洗剪吹的”。
“嗯,好,那我就剪38块的。”
一说完,人家就招呼一个漂亮的妹子带我洗头去了。
我才躺下,那妹子才刚刚把我头发润湿,就开口问道:“帅哥,看你像第一次来,你是住这附近的么?”
“没有,旅游过来的。”
“北京?”她洗发的动作格外轻柔。
“没有没有,看把你吓得,深圳。”
“深圳是个好城市啊!”
我还没来得及张口,妹子继续笑吟吟的,“哥,你发现没有,你声音好有磁性哦!”
我心里隐隐乐开了花,只是仍然假装不为所动,“有么?”
“真的,我都爱上了。”
沉浸在喜悦里无法自拔,妹子又继续问着我。
“帅哥,我们可以洗脸和肩颈按摩二选一,你要哪个?”
今天写curl请求时,其中一行要指定post请求的参数。
当请求头部Content-Type为application/json时,post请求参数需要json_encode转换一下,否则就用http_build_query转换一下。
当写到如下判断时,才想到自己对false>=0的情况有点疑惑:
if(strpos(trim(strtolower($header['Content-Type'])), 'application/json') >= 0){
curl_init($ch, CURLOPT_POSTFIELDS, json_encode($post_data) );
}
当下立马去求证了一下:
false>=0的结果为真
所以上面代码判断方式不妥,后面直接改成0 === strpos()这种方式了。