gorm操作MySql数据库的方法

 更新时间:2021年03月06日 12:06:18   作者:fbbqt  
这篇文章主要介绍了gorm操作MySql数据库的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

1、表中字段区分大小写的设置

在使用gorm查询的时候,会出现账户名Aa是一样的情况,是因为mysql默认不区分大小写造成的

1.问题产生的原因

MySQL在Windows下都不区分大小写。
MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:

1、数据库名与表名是严格区分大小写的;
2、表的别名是严格区分大小写的;
3、列名与列的别名在所有的情况下均是忽略大小写的;
4、变量名也是严格区分大小写的;

MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认的字符集,这个字符集对大小写不敏感,因此在比较过程中中文编码字符大小写转换造成了这种现象。

2、mysql中的排序规则

utf8_bin将字符串中的每一个字符用二进制数据存储,区分大小写。utf8_genera_ci不区分大小写,ci为case insensitive的缩写,即大小写不敏感。utf8_general_cs区分大小写,cs为case sensitive的缩写,即大小写敏感。(注意:在Mysql5.6.10版本中,不支持utf8_genral_cs!!!

3、解决办法

 1、binary关键字

直接修改sql查询语句,在要查询的字段前面加上binary关键字即可。(不推荐)

1、在每一个条件前加上binary关键字

select * from user where binary username = 'admin' and binary password = 'admin';

2、将参数以binary('')包围

select * from user where username like binary('admin') and password like binary('admin');

2、修改Collation属性

创建表时,直接设置表的collate属性为utf8_general_cs或者utf8_bin;如果已经创建表,则直接修改字段的Collation属性为utf8_general_cs或者utf8_bin。

1、修改表结构

ALTER TABLE TABLENAME MODIFY COLUMN COLUMNNAME VARCHAR(50) BINARY CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL;

2、修改字段(使用gorm设置表中字段区分大小写)

`gorm:"unique" sql:"type:VARCHAR(255) CHARACTER SET utf8 COLLATE utf8_bin"`

到此这篇关于gorm操作MySql数据库的方法的文章就介绍到这了,更多相关gorm操作MySql数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql8.0压缩包安装方法(详细教程一步步安装)

    Mysql8.0压缩包安装方法(详细教程一步步安装)

    这篇文章主要给大家介绍了关于Mysql8.0压缩包安装方法,文中介绍的非常详细,Mysql安装的时候可以有msi安装和zip解压缩两种安装方式,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • MySql完整卸载的四个步骤详解

    MySql完整卸载的四个步骤详解

    有时候MySQL不能完全卸载,这时候必须通过一些途径删除掉注册表和一些残余的文件,然后才能重新安装才可以成功,下面这篇文章主要给大家介绍了关于MySql完整卸载的四个步骤,需要的朋友可以参考下
    2022-06-06
  • Windows 10 与 MySQL 5.5 安装使用及免安装使用详细教程(图文)

    Windows 10 与 MySQL 5.5 安装使用及免安装使用详细教程(图文)

    本文介绍Windows 10环境下,MySQL 5.5的安装使用及免安装使用教程,本文提供了资源下载及相关问题解决方案,非常不错,需要的朋友参考下
    2017-07-07
  • mysql实现按照某个时间段分组统计

    mysql实现按照某个时间段分组统计

    这篇文章主要介绍了mysql实现按照某个时间段分组统计方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • 将 Ghost 从 SQLite3 数据库迁移到 MySQL 数据库

    将 Ghost 从 SQLite3 数据库迁移到 MySQL 数据库

    如果网站流量小,直接使用 Ghost 默认的 SQLite 数据库还是很方便的,能够省去安装、配置数据库的繁琐步骤。但是,随着网站流量的增加, SQLite 就慢慢顶不住了,这时最好的选择就是使用 MySQL 数据库。
    2014-07-07
  • mysql实现查询结果导出csv文件及导入csv文件到数据库操作

    mysql实现查询结果导出csv文件及导入csv文件到数据库操作

    这篇文章主要介绍了mysql实现查询结果导出csv文件及导入csv文件到数据库操作,结合实例形式分析了mysql相关数据库导出、导入语句使用方法及操作注意事项,需要的朋友可以参考下
    2018-07-07
  • mysql报1292 Incorrect datetime value错误的解决方法

    mysql报1292 Incorrect datetime value错误的解决方法

    这篇文章主要给大家介绍如何解决mysql报1292 Incorrect datetime value错误,文中有详细的解决方案,具有一定的参考价值,需要的同学可以参考阅读下本文
    2023-07-07
  • 使用FriendFeed来提升MySQL性能的方法

    使用FriendFeed来提升MySQL性能的方法

    这篇文章主要介绍了使用FriendFeed来提升MySQL性能的方法,用其来存储无模式的数据从而能够维护索引,需要的朋友可以参考下
    2015-06-06
  • MySQL分组查询、排序查询、分页查询以及执行顺序

    MySQL分组查询、排序查询、分页查询以及执行顺序

    MySQL数据查询是数据库操作中最常见的操作之一,它可以帮助我们从数据库中获取所需的数据,下面这篇文章主要给大家介绍了关于MySQL分组查询、排序查询、分页查询以及执行顺序的相关资料,需要的朋友可以参考下
    2024-02-02
  • MySQL错误日志与通用查询日志图文详析

    MySQL错误日志与通用查询日志图文详析

    精通MySQL日志管理,这对处理故障与优化太关键了,下面这篇文章主要给大家介绍了关于MySQL错误日志与通用查询日志的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-02-02

最新评论