fae*_*ons 2 mysql database utf-8 iso-8859-1 go
我正在开发一个项目,我们需要将我们的信息保存在具有ISO-8859-1表的遗留数据库中.因此,在向数据库写入内容之前,我需要将其从UTF-8转换为ISO-8859-1,每次从数据库中检索它时,我都需要将其转换回UTF-8.
我试图使用库code.google.com/p/go-charset/作为我需要保留的每个文本字段的以下内容.
import (
"bytes"
"code.google.com/p/go-charset/charset"
_ "code.google.com/p/go-charset/data"
"fmt"
"io/ioutil"
"strings"
)
func toISO88591(utf8 string) string {
buf := new(bytes.Buffer)
w, err := charset.NewWriter("latin1", buf)
if err != nil {
panic(err)
}
defer w.Close()
fmt.Fprintf(w, utf8)
return buf.String()
}
func fromISO88591(iso88591 string) string {
r, err := charset.NewReader("latin1", strings.NewReader(iso88591))
if err != nil {
panic(err)
}
buf, err := ioutil.ReadAll(r)
if err != nil {
panic(err)
}
return string(buf)
}
Run Code Online (Sandbox Code Playgroud)
问题是即使我使用函数toISO88591,数据仍然保持在UTF-8中.我在这次转换中做错了什么?
我的数据库是MySQL,我正在使用github.com/go-sql-driver/mysql驱动程序,其中包含以下连接参数:
<user>:<password>@tcp(<host>:<port>)/<database>?collation=latin1_general_ci
Run Code Online (Sandbox Code Playgroud)
最好的祝福!
Run Code Online (Sandbox Code Playgroud)import "code.google.com/p/go-charset/charset"Run Code Online (Sandbox Code Playgroud)func NewWriter(charset string, w io.Writer) (io.WriteCloser, error)
NewWriter返回一个新的WriteCloser写作w.它将UTF-8文本的写入转换为对w命名字符集中的文本的写入.所述Close冲洗任何残留的部分翻译的字符到所述输出是必要的.
我会按照说明操作:" Close必须将剩余的部分翻译的字符刷新到输出中." 例如,
package main
import (
"bytes"
"code.google.com/p/go-charset/charset"
_ "code.google.com/p/go-charset/data"
"fmt"
"io/ioutil"
"strings"
)
func toISO88591(utf8 string) (string, error) {
buf := new(bytes.Buffer)
w, err := charset.NewWriter("latin1", buf)
if err != nil {
return "", err
}
fmt.Fprintf(w, utf8)
w.Close()
return buf.String(), nil
}
func fromISO88591(iso88591 string) (string, error) {
r, err := charset.NewReader("latin1", strings.NewReader(iso88591))
if err != nil {
return "", err
}
buf, err := ioutil.ReadAll(r)
if err != nil {
return "", err
}
return string(buf), nil
}
func main() {
utfi := "£5 for Peppé"
fmt.Printf("%q\n", utfi)
iso, err := toISO88591(utfi)
if err != nil {
fmt.Println(err)
}
fmt.Printf("%q\n", iso)
utfo, err := fromISO88591(iso)
if err != nil {
fmt.Println(err)
}
fmt.Printf("%q\n", utfo)
fmt.Println(utfi == utfo)
}
Run Code Online (Sandbox Code Playgroud)
输出:
"£5 for Peppé"
"\xa35 for Pepp\xe9"
"£5 for Peppé"
true
Run Code Online (Sandbox Code Playgroud)