【PostgreSQL】全角から半角へ変換する

2020年6月21日

スポンサーリンク

説明

全角から半角へ変換する。

 

引数

引数1(character varying):変換する文字列

 

返り値

変換後の文字列

 

コード

CREATE OR REPLACE FUNCTION convert_full_to_half(character varying)
  RETURNS character varying AS
$BODY$
declare

	c_full	alias for $1;      --引数:置換する文字列

begin

	--アルファベットの変換
	c_full = translate(c_full,
	'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',
	'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'
	);
	
	--数値の変換
	c_full = translate(c_full,
	'1234567890',
	'1234567890'
	);
		
	--カタカナ(濁音)
	c_full := replace(replace(replace(replace(replace(replace(c_full,'ヴ','ヴ' ),'ガ','ガ' ),'ギ','ギ' ),'グ','グ' ),'ゲ','ゲ' ),'ゴ','ゴ' );
	c_full := replace(replace(replace(replace(replace(c_full,'ザ','ザ' ),'ジ','ジ' ),'ズ','ズ' ),'ゼ','ゼ' ),'ゾ','ゾ' );
	c_full := replace(replace(replace(replace(replace(c_full,'ダ','ダ' ),'ヂ','ヂ' ),'ヅ','ヅ' ),'デ','デ' ),'ド','ド' );
	c_full := replace(replace(replace(replace(replace(c_full,'バ','バ' ),'ビ','ビ' ),'ブ','ブ' ),'ベ','ベ' ),'ボ','ボ' );
	c_full := replace(replace(replace(replace(replace(c_full,'パ','パ' ),'ピ','ピ' ),'プ','プ' ),'ペ','ペ' ),'ポ','ポ' );
	
	--カタカナ
	c_full = translate(c_full,
	'アイウエオカキクケコサシスセソタチツテトナニヌネノハヒフヘホマミムメモヤユヨラリルレロワヲンァィゥェォヵヶッャュョヮ',
	'アイウエオカキクケコサシスセソタチツテトナニヌネノハヒフヘホマミムメモヤユヨラリルレロワヲンァィゥェォカケッャュョワ'
	);
	
	--記号
	c_full = translate(c_full,
	' !”#$%&()ー-=^~|@‘「[{;+:*」]}、,<。.>・/?_',
	' !"#$%&()ー-=^~|@`「[{;+:*」]}、,<。.>・/?_'
	);
	
	c_full := replace(c_full,'’','''' );
	c_full := replace(c_full,'¥',chr(92) );
	
	return c_full;

end;
$BODY$
  LANGUAGE plpgsql VOLATILE
  COST 100;
ALTER FUNCTION convert_full_to_half(character varying)
  OWNER TO postgres;

※PostgreSQL12で動作確認済み

 

実行例

select * From convert_full_to_half('xyz890ュョワゴドボ/?_’¥'); 
--【結果】:"xyz890ュョワゴドボ/?_'\"

 

他にもこんな関数があります(文字列操作の関数)

文字列をバイト数で計算する

ひらがなをカタカナに置換する

カンマ区切り文字列の指定カンマ箇所を取得する

文字を左のX文字目から○文字切り取る(Mid関数)

文字列中に指定した文字が含まれるかのチェック