mysql: kod błędu [1267]; Nielegalne połączenie zestawień (latin1_general_cs, IMPLICIT) i (latin1_swedish_ci, IMPLICIT) for operation '='

Chcę zrobićpassword kolumna mojej tabeli użytkownikacase sensitive w mysql.

Poniżej znajduje się opis tabeli:

/*Table: mst_user*/

   FIELD          TYPE          COLLATION        
-------------  ------------  -----------------
user_id        VARCHAR(100)  latin1_swedish_ci
first_name     VARCHAR(25)   latin1_swedish_ci
last_name      VARCHAR(25)   latin1_swedish_ci
USER_PASSWORD  VARCHAR(50)   latin1_swedish_ci
user_status    INT(11)       (NULL)           
version_id     INT(11)       (NULL)           
active_status  INT(11)       (NULL)           
user_type      INT(11)       (NULL)    

ZrobićUSER_PASSWORD wielkość liter jest rozróżniana Wykonałem następujące zapytanie:

ALTER TABLE `mst_user` MODIFY `USER_PASSWORD` VARCHAR(50) COLLATE `latin1_general_cs`;

To działało i pole jest teraz rozróżniane.

Ale mam procedurę przechowywania, która wykonuje aSELECT zapytanie w tej tabeli, aby sprawdzić, czy użytkownik istnieje dla podanych poświadczeń.

Stored Proc ::

CREATE PROCEDURE `usp_password_verify`(ip_login_id         VARCHAR(200),
                                 ip_user_password    VARCHAR(200),
                                INOUT success     INT(1),
INOUT tbl_usr_password          VARCHAR(100),
INOUT  pkg_user_password         VARCHAR(100))
BEGIN
  SELECT COUNT(*)
    INTO success
    FROM mst_user
   WHERE UPPER (user_id) = UPPER (ip_login_id)
   AND USER_PASSWORD=ip_user_password;

   SET tbl_usr_password = '';
   SET pkg_user_password= '';
END$

Gdy wywołam ten zapisany proc z kodu java, pojawia się następujący błąd:

**error code [1267]; Illegal mix of collations (latin1_general_cs,IMPLICIT) and (latin1_swedish_ci,IMPLICIT) for operation '='**

Czy ktoś może pomóc, co jest z tym nie tak? Coś, co działa jak proste zapytanie, daje błąd podczas wykonywania go w zapisanym proc !?

questionAnswers(3)

yourAnswerToTheQuestion