mysql
数据库-mysql教程
微信公众号电影源码,vscode命令行打不开,ubuntu进入redis,tomcat密码修改无效,爬虫url不变,popen函数 php,程序猿要不要学seolzw
mysql中怎么修改collationasp大文件上传源码,ubuntu搭建云桌面,爬虫 只能爬到首页,inurl: .php,黑豹seo优化lzw
【问题报错】在数据库插入数据时,varchar 类型的字段插入中文数据时报错。
报错原文:
ERROR 1366 (HY000): Incorrect string value: ‘\xE8\xA5\xBF\xE5\xAE\x89’ for column ‘address’
美图网站源码带数据下载,ubuntu进入界面黑屏,ipad有爬虫吗,分享php,Seo582793lzw
【原因分析】通过
show full columns from user_bean;
语句查看字段的collation属性,发现字段的collation属性值是 latin1_swedish_ci ,说明字段默认为英语。未对汉语进行设置,所以当输入汉语时,mysql会报错为“字符串的值不正确”。【解决方法】
1、编辑mysql的配置文件 /etc/my.cnf,vi /etc/my.cnf
在 [mysqld] 下面加入两行补充
character_set_server=utf8collation_server=utf8_general_ci
2、重启Mysql服务 systemctl restart mysqld
向数据库插入含中文的数据,成功!
注意:上面步骤可以解决以后创建表时字段的collation属性的问题,但前面已经创建的表字段的collation属性值并不会发生变化。
如果要改变之前已经创建好的表,怎么办?
方法1:对原来的表进行修改,可以通过类似语句alter table user_bean change address address varchar(255) character set utf8 collate utf8_general_ci not null;
方法2:删除原来的表,重新再建。
【命令总结】
show full columns from 表名vi /etc/my.cnfcharacter_set_server=utf8collation_server=utf8_general_cisystemctl restart mysqldalter table 表名 change 要修改的字段 字段名 数据类型 character set utf8 collate utf8_general_ci 约束条件;
mysql视频教学