oracle生产五笔简码,oracle数据库根据汉字生成拼音简码

create or replace function f_name_to_pinyin(as_inputstring varchar2, al_len number) return varchar2 is

i number;

ls_ch varchar2(1000);

ls_returnstr varchar2(1000);

begin

if as_inputstring is null then

return null;

end if;

ls_returnstr := null;

i := 1;

loop

ls_ch := substr(as_inputstring, i, 1);

if ascii(ls_ch) < 128 then

ls_returnstr := ls_returnstr || upper(ls_ch);

else

if ls_ch in ('铵', '庵') then

ls_returnstr := ls_returnstr || 'A';

elsif ls_ch in ('蟾') then

ls_returnstr := ls_returnstr || 'C';

elsif ls_ch in ('鑫', '酰', '馨', '逍') then

ls_returnstr := ls_returnstr || 'X';

elsif ls_ch in ('绮', '嗪', '祛', '琪', '倩', '羟', '芩', '杞', '衢') then

ls_returnstr := ls_returnstr || 'Q';

elsif ls_ch in ('膦', '蓼', '榄', '蛎', '蒺', '蔹', '啉', '莨', '苓', '苈', '楝') then

ls_returnstr := ls_returnstr || 'L';

elsif ls_ch in ('癀', '琥', '荟', '藿', '茴', '槲', '斛', '蛤', '昊') then

ls_returnstr := ls_returnstr || 'H';

elsif ls_ch in ('苄', '铋', '檗', '孢') then

ls_returnstr := ls_returnstr || 'B';

elsif ls_ch in ('啶', '黛', '酊', '椴', '菪', '哚') then

ls_returnstr := ls_returnstr || 'D';

elsif ls_ch = '噁' then

ls_returnstr := ls_returnstr || 'E';

elsif ls_ch in ('埚', '枸', '坩', '苷', '橄', '呱', '酐', '甙', '胱', '钴', '蚣') then

ls_returnstr := ls_returnstr || 'G';

elsif ls_ch in ('皲', '芨', '蒺', '戟') then

ls_returnstr := ls_returnstr || 'J';

elsif ls_ch in ('孚', '茯') then

ls_returnstr := ls_returnstr || 'F';

elsif ls_ch in ('蔻', '匮') then

ls_returnstr := ls_returnstr || 'K';

elsif ls_ch in ('蟆', '莓', '咪', '朦', '沐', '嘧', '眸') then

ls_returnstr := ls_returnstr || 'M';

elsif ls_ch in ('脲', '萘', '蛲', '咛') then

ls_returnstr := ls_returnstr || 'N';

elsif ls_ch in ('脘', '薇', '蜈', '菀') then

ls_returnstr := ls_returnstr || 'W';

elsif ls_ch in ('溴', '昔', '蛸') then

ls_returnstr := ls_returnstr || 'X';

elsif ls_ch in ('龈', '橼', '瘀', '翳', '鸦', '吲', '薏', '苡', '萸', '榈') then

ls_returnstr := ls_returnstr || 'Y';

elsif ls_ch in ('佗', '肽', '葶') then

ls_returnstr := ls_returnstr || 'T';

elsif ls_ch = '髯' then

ls_returnstr := ls_returnstr || 'R';

elsif ls_ch = '参' and substr(as_inputstring, i + 1, 1) in ('数','加','考','观') then

ls_returnstr := ls_returnstr || 'C';

elsif ls_ch in ('参', '噻', '麝', '椹', '熵') then

ls_returnstr := ls_returnstr || 'S';

elsif ls_ch in ('哌', '吡', '嘌', '珀', '枇', '杷', '螵') then

ls_returnstr := ls_returnstr || 'P';

elsif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据你输入的汉子 自动生成五笔拼音简码:取每个汉子的拼音的首字母或者每个汉子的五笔的首字母)本人写了两个存储过程 其实几乎差不多 但是往往啊 会因为一点点小问题导致代失败 不过 下面的两个存储过程都是成功的 我是因为那么一点点小问题测试了一个上午才搞定了的:对应存储过程 output的参数 一定要先set@=‘’一下才能使用 否则即便是output被赋值了 可以print,但是通过程序代还是获取不到值的 如下:(具体的在附件里哦,附件里有表数据和存储过程和c#程序代片段):--drop procedure ChineseCode; ----------一 create procedure ChineseCode(@strkey varchar(30),@rekeysPY varchar(30) output, @rekeysWB varchar(30) output) as declare @keylength int declare @nowstep int declare @temppy varchar(20) declare @tempwb varchar(20) declare @tempkey varchar(4) declare @strpy varchar(30) declare @strwb varchar(30) set @keylength=len(@strkey) set @nowstep=1 set @strpy='' set @strwb='' 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。 end set @rekeysPY=@strpy set @rekeysWB=@strwb print @rekeysPY+'--'+@rekeysWB end GO --------------------二 --drop procedure ChineseCode; create procedure ChineseCode ( @strkey varchar(30) , @rekeysPY varchar(30) output, @rekeysWB varchar(30) output) as declare @keylength int declare @i int declare @temppy varchar(10) declare @tempwb varchar(10) declare @tempkey varchar(2) set @keylength=len(@strkey) set @i=1 set @temppy='' set @tempwb='' set @rekeysPY='' set @rekeysWB='' begin while (@i<=@keylength) 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。 print @rekeysPY+'--'+@rekeysWB end GO ----------------三 c#代 PubClass.ContSql db = new MilkDisPatchingManage.PubClass.ContSql(); SqlCommand sqlcmd = new SqlCommand(); sqlcmd.CommandType = CommandType.StoredProcedure; sqlcmd.CommandText = "ChineseCode"; sqlcmd.Parameters.Add("@strkey", SqlDbType.VarChar, 30); sqlcmd.Parameters["@strkey"].Value=this.textBox1.Text.Trim();//.Direction=ParameterDirection.Input; sqlcmd.Parameters.Add("@rekeysPY", SqlDbType.VarChar,30); sqlcmd.Parameters["@rekeysPY"].Direction = ParameterDirection.Output; sqlcmd.Parameters.Add("@rekeysWB", SqlDbType.VarChar,30); sqlcmd.Parameters["@rekeysWB"].Direction = ParameterDirection.Output; int i= db.ExtCom(sqlcmd); this.textBox2.Text = sqlcmd.Parameters["@rekeysPY"].Value.ToString(); this.textBox3.Text = sqlcmd.Parameters["@rekeysWB"].Value.ToString(); db.CloseCon();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值