本文目录一览:
- 1、如何更改mysql数据库的字符集
- 2、关于数据库存储键值对的问题?
- 3、使用set character_set_client=gbk;修改MySql数据库显示修改成功,重新进入后又恢复成原来未修改的时候
- 4、如何修改mysql数据库中,某表某一列的前50条数据的值,(已知修改后的值)
- 5、如何修改MySQL字符集
- 6、mysql 选择一条记录修改后插入原表
如何更改mysql数据库的字符集
(1) 最简单的修改方法,就是修改mysql的my.ini文件中的字符集键值,
如 default-character-set = utf8
character_set_server = utf8
修改完后,重启mysql的服务,service mysql restart
使用 mysql SHOW VARIABLES LIKE ‘character%’;查看,发现数据库编码均已改成utf8
+————————–+———————————+ | Variable_name | Value | +————————–+———————————+ | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | utf8 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | utf8 | | character_set_system | utf8 | | character_sets_dir | D:”mysql-5.0.37″share”charsets” | +————————–+———————————+
(2) 还有一种修改mysql默认字符集的方法,就是使用mysql的命令
mysql SET character_set_client = utf8 ; mysql SET character_set_connection = utf8 ; mysql SET character_set_database = utf8 ; mysql SET character_set_results = utf8 ; mysql SET character_set_server = utf8 ; mysql SET collation_connection = utf8 ; mysql SET collation_database = utf8 ; mysql SET collation_server = utf8 ;
一般就算设置了表的mysql默认字符集为utf8并且通过UTF-8编码发送查询,你会发现存入数据库的仍然是乱码。问题就出在这个connection连接层上。解决方法是在发送查询前执行一下下面这句:
SET NAMES ‘utf8’;
它相当于下面的三句指令:
SET character_set_client = utf8; SET character_set_results = utf8; SET character_set_connection = utf8;
关于数据库存储键值对的问题?
这是前端(应用端)和后端(服务端)的问题,这个应该是每个用户的单独配置,那么应该放在前端而是不是放在后端,如果放在后端,那么每个用户都要读取,那么体验一定不好。
对于前端来说,只要加一个“配置文件”(其实就是一段代码)就可以,然后通过服务端的程序读取这个“配置文件”,就知道相应的顺序了,这样总比,连通服务器读取相应的表,来的要快。
如果非要用数据库解决,那我们做一个假设,有100项,某人将所有的项目变成了从后往前倒着写的,也就是第100项与第1项位置互换,第99项与第2项位置互换,这样,那么最后是第50项与第51项调换,也就是100项完全变换了位置,那么不管你怎么存储,怎么读取,这些项都必须全部保存起来,因为每一项的顺序都变了,所以这个方案并不是十分好。
当然,如果非要这么做的话,那么有一个稍微简单一点的办法,不过也需要前端的配合而且,很可能出现征用的情况,使用效果也不一定能太好。
我的办法是建立userid 10001 10002 10003 这样一张表,说白了就是一张以默认顺序ModuleID(个人觉得这个可能是你的表头代码,如果不是不要介意)为字段名的表,然后每条用户id,对应一组编号比如(默认编号为1,2,3,4):
userid 10001 10002 10003 10004
1 4 3 1 2
2 2 1 4 3
3 1 2 3 4
类似于这样就能直接得到用户的编号顺序了,不过这种还是不如在前端一个配置文件来的舒服(用户修改配置文件后,服务端也会备份(类似于上表这种也可以作为一个客户端配置的备份),但是这种备份比直接修改数据库要要省事不少,至少节省了数据库的资源),而且可能出现征用的问题,比如两个人或更多的人同时修改代码,那么一张表不可能让这么多人同时update,肯定要出现征用,那么服务体验就不会太好(备份的话,不用那么及时,所以征用的可能性不大,即使出现也是发生在后端,用户的体验并没有什么影响)。
以上均为个人理解,共同探讨。
使用set character_set_client=gbk;修改MySql数据库显示修改成功,重新进入后又恢复成原来未修改的时候
1、set xxx 是修改当前你session的设置,是临时性的,也就是说在你exit退出当前mysql连接后就失效的。
2、如果你想永久保存,需要修改mysql的配置文件,默认的地方是/etc/my.cnf中,在[client]的这块的随便一行,加入default-character-set=gbk,之后重启mysql即可。连接mysql后,输入\s,可以看到client端已经变为你想要的字符集了。
# mysql -uroot -p
\s
…
Client characterset: gbk
Conn. characterset: gbk
如何修改mysql数据库中,某表某一列的前50条数据的值,(已知修改后的值)
update 表名 set 列名=修改后的值 ORDER BY id limit 50;
这里的order by 没指明就是默认升序,
如是order by 列名 desc即为降序排列,
使用时需清楚你要修改哪一部分
如何修改MySQL字符集
修改mysql的默认字符集是通过修改它的配置文件来实现的。一般分两种情况:
Windows平台
windows下的mysql配置文件是my.ini,一般在c:windowsmy.ini或者c:winntmy.ini可以直接在这个文件里面加上
default-character-set=gbk #或gb2312,big5,utf8
然后重新启动mysql
service mysql restart或/etc/init.d/mysql restart
或用其他方法重新启动,就生效了。
Unix平台
linux下的mysql配置文件是my.cnf,一般是/etc/my.cnf,如果找不到可以用find命令找一下:
find / -iname my.cnf
在这个文件里面加上
default-character-set=gbk #或gb2312,big5,utf8
然后重新启动mysql
net stop mysql
mysql 选择一条记录修改后插入原表
自身是无法判断的,通过存储过程可以判断,存储过程中先查询,然后再根据结果决定是更新还是新增
原创文章,作者:LUTW,如若转载,请注明出处:https://www.506064.com/n/149206.html