> 백엔드 개발 > PHP 튜토리얼 > update go_member set username = replacement(name,'비한자',''); 한자가 아닌 문자를 쓰는 방법은 무엇입니까?

update go_member set username = replacement(name,'비한자',''); 한자가 아닌 문자를 쓰는 방법은 무엇입니까?

WBOY
풀어 주다: 2016-08-04 09:19:45
원래의
1327명이 탐색했습니다.

go_member 설정 사용자 이름 업데이트 = 교체(사용자 이름,'한자가 아닌 문자','');

데이터베이스에 있는 이름을 바꾸고 싶습니다. 이름이 숫자, 문자, 한자가 아닌 한(즉, 특수 문자가 제거됨) 교체하겠습니다. 어떻게 하나요? ? ?

데이터베이스는 MySQL입니다

답글 내용:

go_member 설정 사용자 이름 업데이트 = 교체(사용자 이름,'한자가 아닌 문자','');

데이터베이스에 있는 이름을 바꾸고 싶습니다. 이름이 숫자, 문자, 한자가 아닌 한(즉, 특수 문자가 제거됨) 교체하겠습니다. 어떻게 하나요? ? ?

데이터베이스는 MySQL입니다

mysql 정규 매칭, 내 로컬 테스트를 해보면 좋다
update go_member set username= '' where username not REGEXP '[[:alpha:]]|[0-9]|[a-z,A-Z]'

------초대해주셔서 감사합니다----
아이디어 1(권장하지 않음): 어리석은 방법, 먼저 모든 데이터를 찾아낸 다음 결과를 필터링합니다(필터 없음 -한자) 데이터는 이러한 데이터의 ID를 기록하고 업데이트합니다

아이디어 2(권장): SQL에서 정규식을 사용하세요. 정규식은 SQL에서도 사용할 수 있습니다. 사용하는 데이터베이스에 따라 다릅니다. 특정 데이터베이스의 구문은 다릅니다. 이는 상황에 따라 다르며 Google에서 직접 검색해 보세요.
예를 들어 Oracle에는 regexp_like, regexp_replace, regexp_substr 및 regexp_instr의 네 가지 정규 표현식 함수가 있습니다.
예:
select from emp where regexp_like ( ename,'^a[a-z]n$'); ename

에서 a로 시작하고 n으로 끝나는 줄을 찾을 수 있습니다.

위의 해결 방법을 바탕으로 Google에 접속하여 직접 알아볼 수 있습니다. . . . 도움이 되길 바랍니다.

PHP를 사용하는 경우 PHP에서 정규식을 사용하여 결과를 일치시키고 필터링하는 것이 가장 좋습니다. 위에서 언급한 것처럼 MySQL은 일반 쿼리 문을 지원하지만 효율성은 떨어집니다.
중국어에 대한 정규 표현식은 /([u4e00-u9fa5])/u이며, 중국어가 아닌 문자를 필터링하는 정규 표현식은 /([^u4e00-u9fa5])/u

입니다.

php utf-8에서 한자 정규 패턴 제공

<code><?php
$str = "one中国你好two";
$preg = "/\p{Han}+/u";
$result = preg_replace($preg, '', $str);
var_dump($result);</code>
로그인 후 복사

P의 소문자는 한자와 일치하고, 대문자의 P는 한자가 아닌 문자와 일치합니다

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿