sql >> Database >  >> RDS >> Mysql

Selecteer en retourneer alleen Checksum (geen tabel) uit de checksum-tabel in mysql

U kunt dit doen per kolom of per som van kolommen. Hieronder staat een test op een tafel van mij.

SELECT sum(crc32(email)) as crc from users;
+-------------+
| crc         |
+-------------+
| 10679459550 |
+-------------+


select sum(crc32(concat(user_id,first_name,last_name,email,reportingManager))) as crc from users;
+------------+
| crc        |
+------------+
| 7196315383 |
+------------+

Bewerken

In een opgeslagen procedure waarbij een databasenaam en een tabelnaam worden doorgegeven, zal het onderstaande de crc. Het gaat naar de speciale INFORMATION_SCHEMA db om de kolomnamen voor u op te halen, en gebruikt al die kolommen en waarden om een ​​controlesom te genereren.

Opgeslagen procedure:

drop procedure if exists getTableCRC32;
DELIMITER $$
create procedure getTableCRC32
(   dbname varchar(80),
    tableName varchar(80)
)
BEGIN
    set @sql1="select GROUP_CONCAT(`column_name` SEPARATOR ',') into @colNames";
    set @sql1=concat(@sql1," FROM `INFORMATION_SCHEMA`.`COLUMNS`");
    set @sql1=concat(@sql1," WHERE `TABLE_SCHEMA`='",dbName,"'");
    set @sql1=concat(@sql1," AND `TABLE_NAME`='",tableName,"'");
    -- select @sql1;
    PREPARE stmt1 FROM @sql1;
    EXECUTE stmt1;
    DEALLOCATE PREPARE stmt1;
    -- select @colNames;
    set @sql2=concat( 'select sum(crc32(concat(',  @colNames, '))) as crc from ',tableName);
    -- select @sql2;
    PREPARE stmt2 FROM @sql2;
    EXECUTE stmt2;
    DEALLOCATE PREPARE stmt2;
END
$$
DELIMITER ;

Test het:

call getTableCRC32('so_gibberish','users');
+------------+
| crc        |
+------------+
| 7196315383 |
+------------+
call getTableCRC32('so_gibberish','fish');
+------------+
| crc        |
+------------+
| 3273020843 |
+------------+

Handmatige pagina voor crc32



  1. Hoe een MySQL-database back-uppen in PHP?

  2. PDO::bindParam in een foreach-lus, worden alle waarden als hetzelfde ingesteld?

  3. update als er twee velden zijn, invoegen als dat niet het geval is (MySQL)

  4. Wat is het verwachte gedrag voor meerdere set-retourfuncties in de SELECT-component?