sql >> Database teknologi >  >> RDS >> Mysql

hvad er meningen med at vælge ''-''

Du er minus - fra én tom streng '' til andre:

Se følgende:

mysql> select '';
+--+
|  |
+--+
|  |
+--+
1 row in set (0.00 sec)  

mysql> select '3'-'2';
+---------+
| '3'-'2' |
+---------+
|       1 |
+---------+
1 row in set (0.00 sec)

Men advarsel, hvis det ikke er en talstreng :

mysql> select 'a'-'b';
+---------+
| 'a'-'b' |
+---------+
|       0 |
+---------+
1 row in set, 2 warnings (0.00 sec)    

To advarsler:

mysql> SHOW WARNINGS LIMIT 2
    -> ;
+---------+------+---------------------------------------+
| Level   | Code | Message                               |
+---------+------+---------------------------------------+
| Warning | 1292 | Truncated incorrect DOUBLE value: 'a' |
| Warning | 1292 | Truncated incorrect DOUBLE value: 'b' |
+---------+------+---------------------------------------+
2 rows in set (0.00 sec)  

Hvorfor ingen advarsel for empty streng?

Hvor der ikke er nogen advarsel for tom streng, fordi dens(castede noget) 0 se nedenfor:

mysql> SELECT 0 = '';
+--------+
| 0 = '' |
+--------+
|      1 |
+--------+
1 row in set (0.00 sec)   

derfor ved at gøre ''-'' du laver 0 - 0

mysql> SELECT '' - '';
+---------+
| '' - '' |
+---------+
|       0 |
+---------+
1 row in set (0.00 sec)  

For at være mere klar tilføjer jeg følgende eksempel (Jeg føler, at det vil være nyttigt for dig ):
Hvordan konvertering sker:

mysql> SELECT '0' = 0
    -> ;
+---------+
| '0' = 0 |
+---------+
|       1 |
+---------+
1 row in set (0.00 sec)  

bemærk dens konvertering:

mysql> SELECT '' = '0'
    -> ;
+----------+
| '' = '0' |
+----------+
|        0 |
+----------+
1 row in set (0.00 sec)  

'' konverteret til 0 , '0' konverteret til 0 men '' ikke lig med '0'

mysql> SELECT '1' = 1
    -> ;
+---------+
| '1' = 1 |
+---------+
|       1 |
+---------+
1 row in set (0.00 sec)

mysql> SELECT '' = 1
    -> ;
+--------+
| '' = 1 |
+--------+
|      0 |
+--------+
1 row in set (0.00 sec) 


  1. Hvordan tvinger jeg Postgres til at bruge et bestemt indeks?

  2. MySQL (STANDARD + VED OPDATERING) TIMESTAMPS

  3. org.apache.openjpa.persistence.ArgumentException mens du kører hovedklassen

  4. node-mysql fejl:tilslut ECONNREFUSED