我对sql没有那么有经验,这是我的(也许是愚蠢的)问题:
我有以下查询
select *
from myTable
where lower(replace(lastname, 'ü', 'ue')) = lower(replace(someStr, 'ü', 'ue'))
是否可以替换
lower(replace(lastname, 'ü', 'ue')) = lower(replace(someStr, 'ü','ue'))
有功能吗?
这样的事情:
select *
from idmanlight.nethz_user
where myFunction(lastname) = myFunction(someStr)
我尝试用这种方式定义函数:
CREATE FUNCTION myFunction(IN str character varying) RETURNS void AS $$
LOWER(replace(replace(replace((str, 'ü', 'ue'), 'ä', 'ae'), 'ö', 'oe'));
$$ LANGUAGE sql;
但是运行它我得到了错误
错误:语法错误»LOWER«SQL状态:42601字符:88
我找到的所有示例都总是选择,删除,更新,插入函数体内。
实际上可以定义一个没有选择,删除,更新,插入的功能吗?
我正在使用PostgresSql 9.2。
答案 0 :(得分:3)
语法错误是由于sql语法和错误的返回值:
CREATE FUNCTION myFunction(str text) RETURNS text AS $$
SELECT LOWER(replace(replace(replace((str, 'ü', 'ue'), 'ä', 'ae'), 'ö', 'oe'));
$$ IMMUTABLE STRICT LANGUAGE sql;
替代,更完整的功能:
CREATE OR REPLACE FUNCTION translit(text)
RETURNS text
AS $$
DECLARE
_str text := $1;
_find constant text := 'ÀÁÂÃÄÅĀĄĂÆÈÉÊËĒĘĚĔĖÐÌÍÎÏĪĨĬĮİIJÒÓÔÕÖØŌŐŎŒÙÚÛÜŪŮŰŬŨŲÝŶŸ' ||
'àáâãäåāąăæèéêëēęěĕėðìíîïīĩĭįıijòóôõöøōőŏœùúûüūůűŭũųýÿŷ' ||
'ÇĆČĈĊĎĐƑĜĞĠĢĤĦĴĶŁĽĹĻĿÑŃŇŅŊŔŘŖŚŠŞŜȘſŤŢŦȚÞŴŹŽŻ' ||
'çćčĉċďđƒĝğġģĥħĵĸķłľĺļŀñńňņʼnŋŕřŗśšşŝșßťţŧțþŵžżź';
_repl constant text := 'AAAAAAAAAAEEEEEEEEEEIIIIIIIIIIOOOOOOOOOOUUUUUUUUUUYYY' ||
'aaaaaaaaaaeeeeeeeeeeiiiiiiiiiioooooooooouuuuuuuuuuyyy' ||
'CCCCCDDFGGGGHHJKLLLLLNNNNNRRRSSSSSSTTTTTWZZZ' ||
'cccccddfgggghhjkklllllnnnnnnrrrsssssstttttwzzz';
BEGIN
-- Bail if the string is empty.
IF _str = ''
THEN
RETURN _str;
END IF;
-- Common expansions.
_str := replace(_str, 'ſ', 'SS');
_str := replace(_str, 'ß', 'ss');
_str := replace(_str, 'Å', 'AA');
_str := replace(_str, 'å', 'aa');
_str := replace(_str, 'IJ', 'IJ');
_str := replace(_str, 'ij', 'ij');
_str := regexp_replace(_str, '([ÄÆÖŒÜ])', E'\\1E', 'g');
_str := regexp_replace(_str, '([äæöœü])', E'\\1e', 'g');
-- Translate what's left.
_str := translate(_str, _find, _repl);
RETURN _str;
END;
$$ IMMUTABLE STRICT LANGUAGE plpgsql COST 1;
答案 1 :(得分:2)
不归还无效。你有语法问题。它应该返回一个字符串,并有一个如下语句:
RETURN LOWER(...)
或
RETURN SELECT LOWER(...)