如何修改 Mysql 表 的属性(将只读改为可读写),只改表不改库

如何修改 Mysql 表 的属性(将只读改为可读写),只改表不改库,第1张

如果是sqlserver数据库,其实对于某列上不存在不让修改的说法,sqlserver数据库数据控制原理是角色控制,也就是说我们对于某一个角色去下定义,让隶属于这个角色的用户不能够更新数据。或者在某个角色的基础上不分配或是回收对某一列的权限!如果是这种情况,用一个能修改的角度登陆才行。

还有另一种就是所谓的触发器,一旦发现你修改,立即返回原数据,这样你也是永远修改不了的!这时你要找到那个触发器,将触发器删除后再进行修改,然后加回触发器即可!

但这两种情况都是对某一列下的定义(我们称为锁定粒度为列)不可能是某一个单元格!

如果你是站在erp管理的基础上不让你修改那是十分正常的!

在企业管理器中使用图形方式(如二楼给的图)还是语句,则没有任何的区别!

mysql中怎么修改collation

【问题报错】

在数据库插入数据时,varchar 类型的字段插入中文数据时报错。

报错原文:

【原因分析】

通过 show full columns from user_bean语句查看字段的collation属性,发现字段的collation属性值是 latin1_swedish_ci ,说明字段默认为英语。未对汉语进行设置,所以当输入汉语时,mysql会报错为“字符串的值不正确”。

【解决方法】

1、编辑mysql的配置文件 /etc/my.cnf,vi /etc/my.cnf

在 [mysqld] 下面加入两行补充

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:删除原来的表,重新再建。

【命令总结】


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7166158.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-02
下一篇 2023-04-02

发表评论

登录后才能评论

评论列表(0条)

保存