今天彻底郁闷到了,折腾了一上午.终于明白了sqlit3编码,和string 编码转换问题.总算有点收获.下面就拿出来晒一晒.
我插入数据
ContentValues value = new ContentValues(2);
value.put(table.city.ID, "1");
value.put(table.city.NAME, "北京");
Log.d("tag4", new String("北京"));
this.getContentResolver().insert(CityProvider.URI_CITY, value);
用sqlit自带的工具查看时乱码,当时我就急了.怎么会是乱码呢!原因sqlit3编码方式是GB2312,而显示到我们面前的是UTF-8或者GBK方式,所以乱了
当我查询出来用eclipse看是就不是乱码了心里也不慌了,因为已经自动转换成UTF-8或者GBK显示出来了
虽然最后可能是我自己白忙活,整套机制起始android ecliipse sqlit 他们早就已经帮您弄好了,不需要你操心.但是我也学习了一下编码转换的知识:
String 转GB2312 String s = new String("北京".getBytes("GB2312"),"GB2312")
String 转UTF-8 String s = new String("北京".getBytes("UTF-8"),"UTF-8")
String 转GBK String s = new String("北京".getBytes("GBK"),"GBK")