Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

점 앞에 문자열의 일부를 대체하는 MySQL 쿼리

<시간/>

이를 위해 SUBSTRING_INDEX()와 함께 CONCAT()을 사용합니다. 먼저 −

를 생성해 보겠습니다.
mysql> create table DemoTable1424
   -> (
   -> Value varchar(60)
   -> );
Query OK, 0 rows affected (0.56 sec)

insert −

를 사용하여 테이블에 일부 레코드 삽입
mysql> insert into DemoTable1424 values('567.78483733');
Query OK, 1 row affected (0.78 sec)
mysql> insert into DemoTable1424 values('1023.45252443');
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable1424 values('7893322.5635543434');
Query OK, 1 row affected (0.35 sec)
mysql> insert into DemoTable1424 values('90944.665665');
Query OK, 1 row affected (0.14 sec)

select −

를 사용하여 테이블의 모든 레코드 표시
mysql> select * from DemoTable1424;

이것은 다음과 같은 출력을 생성합니다 -

+--------------------+
| Value              |
+--------------------+
| 567.78483733       |
| 1023.45252443      |
| 7893322.5635543434 |
| 90944.665665       |
+--------------------+
4 rows in set (0.00 sec)

다음은 dot −

앞의 문자열 일부를 바꾸는 쿼리입니다.
mysql> update DemoTable1424
   -> set Value=concat('10000.',substring_index(Value ,'.',-1));
Query OK, 4 rows affected (0.13 sec)
Rows matched: 4  Changed: 4 Warnings: 0

다시 한번 테이블 기록을 확인해보자 -

mysql> select * from DemoTable1424;

이것은 다음과 같은 출력을 생성합니다 -

+------------------+
| Value            |
+------------------+
| 10000.78483733   |
| 10000.45252443   |
| 10000.5635543434 |
| 10000.665665     |
+------------------+
4 rows in set (0.00 sec)