PHP - Requête de données basée sur des lettres. Je souhaite créer un nouveau champ dans le tableau pour enregistrer la première lettre de chaque caractère chinois. Quelles sont les instructions dans MySQL ? Comment obtenir la première lettre de chaque caractère chinois ?
高洛峰2017-05-24 11:31:19
0
2
736
1. Y a-t-il un maître PHP qui a réalisé ce genre de fonction ? Veuillez me guider 2. Toute personne ayant une expérience avec MySQL, veuillez me guider
Quelle est la taille de la table qui contient des lettres comme celle-ci ? . .
-- 建立汉字转换拼音函数
DROP FUNCTION IF EXISTS to_pinyin;
DELIMITER $
CREATE FUNCTION to_pinyin(NAME VARCHAR(255) CHARSET gbk)
RETURNS VARCHAR(255) CHARSET gbk
BEGIN
DECLARE mycode INT;
DECLARE tmp_lcode VARCHAR(2) CHARSET gbk;
DECLARE lcode INT;
DECLARE tmp_rcode VARCHAR(2) CHARSET gbk;
DECLARE rcode INT;
DECLARE mypy VARCHAR(255) CHARSET gbk DEFAULT '';
DECLARE lp INT;
SET mycode = 0;
SET lp = 1;
SET NAME = HEX(NAME);
WHILE lp < LENGTH(NAME) DO
SET tmp_lcode = SUBSTRING(NAME, lp, 2);
SET lcode = CAST(ASCII(UNHEX(tmp_lcode)) AS UNSIGNED);
SET tmp_rcode = SUBSTRING(NAME, lp + 2, 2);
SET rcode = CAST(ASCII(UNHEX(tmp_rcode)) AS UNSIGNED);
IF lcode > 128 THEN
SET mycode =65536 - lcode * 256 - rcode ;
SELECT CONCAT(mypy,pin_yin_) INTO mypy FROM t_base_pinyin WHERE CODE_ >= ABS(mycode) ORDER BY CODE_ ASC LIMIT 1;
SET lp = lp + 4;
ELSE
SET mypy = CONCAT(mypy,CHAR(CAST(ASCII(UNHEX(SUBSTRING(NAME, lp, 2))) AS UNSIGNED)));
SET lp = lp + 2;
END IF;
END WHILE;
RETURN LOWER(mypy);
END;
$
DELIMITER ;
Il n'est pas nécessaire d'utiliser MySQL pour exécuter la fonction de lettre initiale...
PHP peut le gérer.
<?php
fonction getfirstchar($s0){
}
fonction pinyin1($zh){
}
echo pinyin1('Ceci est une chaîne chinoise');
Quelle est la taille de la table qui contient des lettres comme celle-ci ? . .