paip.输入法编程---带ord gudin去重复-
paip.输入法编程---带ord gudin去重复-
作者Attilax , EMAIL:1466519819@qq.com
来源:attilax的专栏
地址:http://blog.csdn.net/attilax
--------查询重复(不同ORD)
SELECT
hezi,
atian,
gudin,
count(id) AS num
FROM
gaopinzi
WHERE
LENGTH(atian) > 0 and ( del is null or del=0) and lang='chinese'
GROUP BY
hezi,
atian
HAVING
num > 1
-----------加入临时表.
DELETE from tmp_tsiku;
insert tmp_tsiku(hezi,atian,gudin,lang)
SELECT
hezi,
atian,
gudin,
count(id) AS num
FROM
gaopinzi
WHERE
LENGTH(atian) > 0 and ( del is null or del=0) and lang='chinese'
GROUP BY
hezi,
atian
HAVING
num > 1
;
select * from tmp_tsiku
去重复存储过程 conf_del
----------------------
原理如下:
for( tmp_tsiku )
if(getTsityao_count(hezi,py))
{
baolyeu_id= get_top1(hezi,py);
del_other(hezi,py,baolyeu_id);
}
BEGIN
#Routine body goes here...
declare tmpName varchar(200) default '' ;
declare var_ati varchar(200) default '' ;
declare havgudin int;
declare gundi_id int;
declare rownum int;
declare tsityao_count int;
declare baolyeu_id int;
declare tmpint int;
DECLARE isRecordNotFound int;
declare cur1 CURSOR FOR select hezi,atian from tmp_tsiku where 1=1 ;
declare continue handler for not found set isRecordNotFound = 1;
-- Oracle的PL/SQL的指针有个隐性变量%notfound,
-- Mysql是通过一个Error handler的声明来进行判断的,
-- declare continue handler for Not found (do some action);
-- 在Mysql里当游标遍历溢出时,会出现一个预定义的NOT FOUND的Error,
-- 我们处理这个Error并定义一个continue的handler就可以了
-- 下面一句不能没有,否则将会进不了while循环
set isRecordNotFound = 0;
set rownum=1;
/*开游标*/
#set tmpName=; set var_ati
OPEN cur1;
/*游标向下走一步*/
FETCH cur1 INTO tmpName,var_ati;
/* 循环体 这很明显 把游标查询出的 name 都加起并用 ; 号隔开 */
WHILE ( isRecordNotFound = 0 ) DO
set tsityao_count=getTsityao_count(tmpName,var_ati);
if tsityao_count>1 THEN
select havgudin,rownum ;
set
baolyeu_id= get_top1(tmpName,var_ati);
select gundi_id,rownum ;
set
tmpint= del_other(tmpName,var_ati,baolyeu_id);
end if;
set rownum=rownum+1;
/*yao jya jeig select ,beri zweiheu yg result b show chwlai.. */
select 'the end';
/*游标向下走一步*/
FETCH cur1 INTO tmpName,var_ati;
END WHILE;
CLOSE cur1;
END
-------getTsityao_count---------
BEGIN
#Routine body goes here...
DECLARE gudinid int ;
set @gudinid= (
SELECT
COUNT(*)
FROM
gaopinzi
WHERE
(del IS NULL OR del = 0)
AND lang = 'chinese'
AND hezi = hezi
AND atian =py
);
RETURN @gudinid;
END
--------get_top1-----------
BEGIN
#Routine body goes here...
DECLARE gudinid int ;
set @gudinid= ( select id from gaopinzi where lang='chinese' and HEZI=hezix and ATIAN=py
and (del is null or del=0)
order by gudin desc,ord,id
limit 1
);
RETURN @gudinid;
END
---------del_other---------
BEGIN
#Routine body goes here...
#select SQL_NO_CACHE del_no_gudin ('一','y',3192) c1
declare tmpName INT;
/*
update gaopinzi set del=1,deltime=now(),dely='del no-gudin'
*/
#SET NAMES 'utf8';
insert tmp(id,hezi,py)
select id,hezi,atian from gaopinzi
where lang='chinese' and HEZI=hezix and atian=py
and ( del is null or del=0)
and id!=baolyeuid
;
RETURN tmpName;
END
检查得到的tmp是否OK.
-----------
触发器日志
---------
以便进行误删除恢复..
CREATE TRIGGER `deladdtime` AFTER UPDATE ON `gaopinzi` FOR EACH ROW begin
insert logx(idop,eventx,timex,demo,hezi,pyold,pynew)values( old.id,'update rec',now(),'',old.hezi,old.atian,new.atian);
end;
删除虫复
-----------
update gaopinzi set del=1,deltime=now(),dely='del no-gudin'
where id in (select id from tmp)
----------恢复误删除的记录
select * from logx WHERE id>=6 and id<=10
(select idop from logx WHERE id>=6 and id<=10);
select * from gaopinzi where id in (13083,15319,15736,16030,137815);
UPDATE gaopinzi set del=0,deltime=now(),dely='hweif' where id in (13083,15319,15736,16030,137815);
select * from gaopinzi where id=137815
------------------已下为测试SQL--------------
------------------已下为测试SQL--------------
select * from gaopinzi where lang='chinese' and HEZI='七' and ( del is null or del=0) order by id
limit 7;
select * from gaopinzi where lang='chinese' and HEZI='一' and ( del is null or del=0)
exec QUERY_chonf_nosame_ord
-----查询是否有重复的记录...
SELECT
COUNT(*)
FROM
gaopinzi
WHERE
LENGTH(hezi) = 3
AND (del IS NULL OR del = 0)
AND lang = 'chinese'
AND hezi = '针'
AND atian = 'jenjs'
ORDER BY
gudin DESC,
ord
-------得到要保留的ID
SELECT
*
FROM
gaopinzi
WHERE
LENGTH(hezi) = 3
AND (del IS NULL OR del = 0)
AND lang = 'chinese'
AND hezi = '针'
AND atian = 'jenjs'
ORDER BY
gudin DESC,
ord
LIMIT 1
------删除其他记录.
update gaopinzi set del=1 where
LENGTH(hezi) = 3
AND (del IS NULL OR del = 0)
AND lang = 'chinese'
AND hezi = '针'
AND atian = 'jenjs'
and id!=@top1
select * from gaopinzi
where lang='chinese' and HEZI='一' and atian='y'
and ( del is null or del=0)
and gudin=0 and id!=3192
=============
update gaopinzi set del=1 ,dely='test' where id=7106 and atian='cy'
update gaopinzi set del=1 ,dely='test' where id=7106 and atian='cy'
select * from gaopinzi where id=7106
select * from tmp
select hezi,atian from gaopinzi where lang='chinese' and (del is null or del=0) and LENGTH(hezi)=3
and ord=99 order by hezi
select * from gaopinzi where lang='chinese' and (del is null or del=0) and LENGTH(hezi)=3 and ord=99
order by hezi
select havgudin('针','jen')
select havgudin('一','y')
paip.输入法编程---带ord gudin去重复-的更多相关文章
- paip.输入法编程----删除双字词简拼
paip.输入法编程----删除双字词简拼 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/at ...
- paip.输入法编程---增加码表类型
paip.输入法编程---增加码表类型 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/attil ...
- paip输入法编程之生活用高频字,以及汉字分级
paip输入法编程之生活用高频字 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/attilax ...
- paip.输入法编程----一级汉字1000个
paip.输入法编程----一级汉字1000个.txt 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn. ...
- paip.输入法编程---输入法ATIaN历史记录 c823
paip.输入法编程---输入法ATIaN历史记录 c823 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csd ...
- paip.输入法编程--英文ati化By音标原理与中文atiEn处理流程 python 代码为例
paip.输入法编程--英文ati化By音标原理与中文atiEn处理流程 python 代码为例 #---目标 1. en vs enPHati 2.en vs enPhAtiSmp 3.cn vs ...
- paip.输入法编程---词库多意义条目分割 python实现.
paip.输入法编程---词库多意义条目分割 python实现. ==========子标题 python mysql 数据库操作 多字符分隔,字符串分割 字符列表循环 作者 老哇的爪子 Attil ...
- paip.输入法编程---词频顺序order by py
paip.输入法编程---词频顺序order by py 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn ...
- paip.输入法编程---智能动态上屏码儿长调整--.txt
paip.输入法编程---智能动态上屏码儿长调整--.txt 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csd ...
随机推荐
- 与useradd命令相关的两个默认配置文件
Configuration Files for User Management Defaults When working with tools as useradd, some defaul ...
- C++输出hello world 详细注释
/* #include<iostream> #:预处理标志,后面跟预处理指令,include:预处理指令,包含 <iostream>:c++头文件,输入输出流 这行的作用就是在 ...
- MediaPlayer 音频播放 示例
状态机.流程图.生命周期 对播放音频/视频文件和流的控制是通过一个状态机来管理的.下图显示一个MediaPlayer对象被支持的播放控制操作驱动的生命周期和状态. 椭圆代表MediaPlayer对象可 ...
- 返回到上一页的html代码的几种写法
关键词:返回上一页 html代码超链接返回上一页代码: <a href=”#” onClick=”javascript :history.back(-1);”>返回上一页</a> ...
- MySQL查看数据库大小、表大小和最后修改时间
查看数据库表基本信息. select * from information_schema.TABLES where information_schema.TABLES.TABLE_SCHEMA = ' ...
- MySQL忘记root密码的解决方案
在实际操作中忘记MySQL的root密码是一件令人很头痛的事情,不要急以下的文章就是介绍MySQL的root密码忘记的时候解决方案,我们可以对其进行如下的步骤重新设置,以下就是文章的详细内容描述. ...
- php魔法常量
有七个魔术常量它们的值随着它们在代码中的位置改变而改变.例如 __LINE__ 的值就依赖于它在脚本中所处的行来决定.这些特殊的常量不区分大小写,如下: 名称 说明 __LINE__ 文件中的当前行号 ...
- php中iconv函数的一个小bug--转载
iconv转换字符集很好用,但是有时候你会发现iconv转换的时候会返回false或者空字符串,严格说来这算不上是iconv的问题,这其实是字符集的问题,但是实际编码中应该算是iconv的bug了. ...
- R2:获取一个event_base
原文链接:http://www.wangafu.net/~nickm/libevent-book/Ref2_eventbase.html 创建一个event_base 在你使用任何有意思的Libeve ...
- 安装beautifulsoup的奇怪问题
以前用的python2.7,改成3.4以后就重新下载了beatifulsoup4.解压到c:\Python34后.在cmd界面执行python setup.py install安装完成后.想看看安装成 ...