|
哎,我的3p丢了,要不就能和lz并肩战斗解决短信问题了.
a) L; V0 ^: G* j) {2 x& s6 y% {9 e% l5 R. `8 I
CREATE TRIGGER [erro_msg_insert] AFTER INSERT On [com_palm_messaging_data_ChatThread] FOR EACH ROW
1 X/ @2 v* R+ e) f, y. F& lwhen, A" _2 j" j7 @3 @% ^
(lower(hex(new.summary)) LIKE '%e280a9%') and (new.type='SMS')4 O# D. @, ^3 Z. Z4 o7 k+ Y
begin
" G9 g# V4 d5 n% K% \ update com_palm_messaging_data_chatthread : f% M& u! {; L2 }4 @
set summary ='*********' 8 a2 }6 K" A! P' X; ~ h' {
where id=new.id;
5 |% N/ f0 H8 |end;5 [( }3 U- I: A! C# p: d
以上这段代码,是我为了解决短信问题作的探索.它是一个触发器,只能在问题短信出现后更改插入内容,因为3p丢之前没有发生过短信问题,就不知道好不好用.但是如果抓正常短信是毫无问题的.
+ m9 o' n2 R. t: L$ J2 U& X- l
+ J- x& Q, x. K解释: 第一行 for each row可以不加,sqlite的一本书里解释sqlite只能以each row方式操作; L& Q0 e( z6 ~& s/ J
关键第三行判断,hex函数取字符换16进制数(在sqlite网站我没找到将16进制数转字符串的函数),lower转换为小写,例如4E,变为4e,like后的是板上有人说出问题的特殊符号的16进制值“e280a9” %为若干字符的通配符 and后判断插入的是短信而不是邮件等其他的。- c1 _; ~# |' G
第6行,“****”是替换的字符串,因为没找到16进制转字符串的函数所以就没办法把问题短信去除特殊字符后再转回去,只能完全擦除。
- H2 n& W/ ?2 g% F) t) U' c5 t+ I* F! }& _
关键是要找到问题短信16进制特征,我用“6263”也就是bc两个字符试了,抓到完全没问题,因为是after tirgger,所以短信预览时还是bc,打开短信软件就变成****了,sqlite支持before tirgger,但是如何在抓住短信后改new纪录的字段内容我还没搞出来,3p就离我而去了。只能做这些了 |
|