2

このクエリは MySQL で実行でき、問題なく動作します。しかし、ctd.FULL_DESCRIPTION (TEXT データ型) で LEFT 関数を実行し、最初の 3600 文字だけを取得する必要があり、それを実行しようとすると (LEFT(ctd.FULL_DESCIPTION, 3600) を使用して) エラーが発生します: 不正な混合の操作「UNION」の照合 (utf8_general_ci,IMPLICIT) および (latin1_swedish_ci,COERCIBLE)

このエラーで見つかったすべてのことは、私の列の 1 つが他の列と同じように照合されていないことを示しています。このクエリのすべてのテーブルで SHOW FULL COLUMNS を実行しましたが、照合されたものはすべて utf8_general_ci を使用しています。データベースのデフォルトの照合順序も utf8 です。どこでも latin1_swedish_ci になっている場所が見つかりません。私は何が欠けていますか?

SELECT 
CONCAT(''73'',RIGHT(CONCAT(''000000'',cd.CHANGEID),6)) AS CHANGEID, 
LEFT(cd.TITLE,80) AS CHANGETITLE, FROM_UNIXTIME(cd.CREATEDTIME/1000) AS PRJDATE, 
LEFT(sd.NAME,10) AS STATUSNAME, wo.WORKORDERID AS WOID, LEFT(wo.TITLE,80) AS WOTITLE,
LEFT(au.FIRST_NAME,10) as TECHNAME, ctd.FULL_DESCRIPTION AS CHANGEDSC
FROM servicedesk.changedetails cd, servicedesk.incidenttochangemapping itcm, 
servicedesk.workorder wo, servicedesk.stagedefinition sd, servicedesk.workorderstates 
wos, servicedesk.sduser sdu, servicedesk.aaauser au, servicedesk.changetodescription ctd 
WHERE cd.CHANGEID = itcm.CHANGEID and itcm.WORKORDERID = wo.WORKORDERID and
cd.STAGEID = sd.STAGEID and wo.WORKORDERID = wos.WORKORDERID and wos.OWNERID = 
sdu.USERID and sdu.USERID = au.USER_ID and cd.CHANGEID = ctd.CHANGEID and
cd.STAGEID NOT IN (3,2) and cd.CATEGORYID IN 
(301,2701,3601,3602,3605,3606,4201,4202,4501,4502,4801) and wos.REQUESTTYPEID IN 
(301,601)
UNION
SELECT CONCAT(''73'',RIGHT(CONCAT(''000000'',cd.CHANGEID),6)) AS CHANGEID, 
LEFT(cd.TITLE,80) AS CHANGETITLE, FROM_UNIXTIME(cd.CREATEDTIME/1000) AS PRJDATE, 
LEFT(sd.NAME,10) AS STATUSNAME, '''' AS WOID, '''' AS WOTITLE, '''' AS TECHNAME, 
ctd.FULL_DESCRIPTION AS CHANGEDSC
FROM servicedesk.changedetails cd, servicedesk.stagedefinition sd,
servicedesk.changetodescription ctd
WHERE cd.STAGEID = sd.STAGEID and cd.CHANGEID = ctd.CHANGEID and cd.STAGEID NOT 
IN (3,2) and cd.CATEGORYID IN
(301,2701,3601,3602,3605,3606,4201,4202,4501,4502,4801) and NOT EXISTS (
SELECT NULL FROM servicedesk.incidenttochangemapping itcm WHERE cd.CHANGEID = 
itcm.CHANGEID)
4

1 に答える 1

4

問題は、システム変数 collat​​ion_connection が latin1_swedish_ci に設定され、それ以外はすべて utf8_general_ci であったことです。collat​​ion_connection を utf8_general_ci に設定すると、クエリを正常に実行できました。

于 2012-10-04T13:56:18.740 に答える