sql >> Database >  >> RDS >> Mysql

wat is de betekenis van selecteren ''-''

Je bent min - van één lege string '' naar andere:

Zie het volgende:

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

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

Maar waarschuwing als het geen een cijferreeks is :

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

Twee waarschuwingen:

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)  

Waarom geen waarschuwing voor empty tekenreeks?

Waar er geen waarschuwing is voor een lege tekenreeks omdat het (iets heeft gecast) 0 zie hieronder:

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

vandaar door ''-'' . te doen je doet 0 - 0

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

Voor meer duidelijkheid voeg ik het volgende voorbeeld toe (Ik denk dat dit nuttig voor je zal zijn ):
Hoe conversie gebeurt:

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

let op de conversie:

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

'' omgezet in 0 , '0' omgezet in 0 maar '' niet gelijk aan '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. converteer lijst naar string om in mijn sql in één rij in python scrapy in te voegen

  2. MySQL-query is langzamer na het maken van de index

  3. PostgreSQL:tijd voor het maken van tabellen

  4. Willekeurige rij selecteren per afzonderlijke veldwaarde?