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
위의 해결 방법을 바탕으로 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는 한자가 아닌 문자와 일치합니다