大佬们你们 Mysql 的数据库名称怎么分割的?
我公司数据库名称采用的是 小写 + 下划线 + 小写 例如 pj0001_prod,但是同事提出了异议说在某些软件使用下划线会出现异常(问了他什么软件又不说).
下划线一般不会有问题,中横线倒是有问题
回复他
“在你写的软件里会出现异常是吗😏”
下划线都有问题。。。这同事新来的吧
但凡看一眼 mysql 自带的mysql
库的结构都不会这么说,表设计完全可以参考它
他菜,一楼说的对,中划线有问题
一楼说的对,下划线放心用,怎么可能有问题: dev.mysql.com/doc/refman/8.4/en/identifiers.html
用的 SQLSERVER ,驼峰
下划线没有任何问题
就喜欢你这种说话好听的同事
可以参考 django 框架的习惯,模块名_表名,小写, 下划线没有问题。
下滑线不会有问题,反而-这种才不建议
他写的软件可能有问题
开发环境如果域名里写 下划线 倒是会有问题
唔,假设说,不用下划线的话,那么用什么呢?
空格?中划线?还是$#@%这种异教?
看来看去,还是只有下划线这一种
绝了,下划线有问题的话我用过的 ORM 全部完蛋。话说除了下划线还有啥常见的分法
听他的, 问问他想怎么分割
下划线是大部分情况下最稳妥的方案。
用驼峰会有个问题就是lower_case_table_names
参数,当值设为 1 时,MySQL 将忽略表名和数据库名的大小写。
打一架!打一架!打一架!打一架!打一架!😡
这都能成为问题,看来你们公司挺闲的
那就采用中文命名,打架都省了
哈哈哈也没有,主要现在服务器要迁库...所以我们就又讨论了一下...
直接打群架是吧
通配符 在 MySQL 中具有特殊含义, 如果数据库名中含有下划线
例如 GRANT ALL ONdb_1.* TO test_user;进行授权操作时,会导致 db01 ,db11 ,db21 ,…,db91 都被匹配。需要将_进行转译才行。
所以还是有坑的,那位同事可能之前看到过但具体想不起来是啥坑了
就是你这个习惯就行了, 已经是问题最少的方案了
那就去掉下划线,直接连写,这样总不会有问题了吧🐶
#13 SQL Server 风格,用驼峰 😂
你同事说的没错。库名不能用下划线,会有坑。我得想想是什么坑 记不清了
#1
#2
#3
#4
#5
#7
人家说的是库名,不是表名
我这边我自己定的公司规范里,数据库名就明确写了不能用下划线,表名不能用减号,但是我不记得有什么坑让我这么规定的了 容我想想
#26 思索
#1
#2
#3
#4
#5
#7
#28
我想了一天也没想起来 然后我刚去问了 chatgpt 可能有什么风险 在 gpt 的提示下 然后大概整明白了当初我为什么这么定的规范
MYSQL 中单下划线在很多场景识别为单字通配符,在赋权等场景,这样会导致可能的风险。
很多 ORM 会识别这个通配符,给你处理好,有些 ORM 并不会 这是风险 1
而且这个可能影响更大的是用各种管理工具或者裸写 SQL 进行运维时,会造成很多莫名其妙的问题
很多管理工具对这个的处理非常不好
不断提升自己,去了更好的公司后,就不会再遇到有这种问题的同事了
#27 大家都知道说的是库名啊。文档里这么写的,哪个软件有问题那是它没有按照 MySQL 规范呗,这种软件还敢用嘛
"Certain objects within MySQL, including database, ... names are known as identifiers. " 这句里面包含 database ,然后 "Permitted characters in unquoted identifiers: ASCII: [0-9,a-z,A-Z$_] (basic Latin letters, digits 0-9, dollar, underscore)"
所以设计模式,实是是一种方法,一种为了解决某种或某类物定问题所使用的设计模型。据说,在编程语言方面有100多种设计模式,而在现实生活中,传说有上成千上万个模式,比如写书有写书的…
以前发布过《C语言的错误处理》一文,不过今天想说的是Egypt的“错误处理”。埃及的事闹得挺大的,国外和中文twitter上更是炸了锅。不要以为程序员就只会写程序——看看程序员…
这东西真的舒服吗?一把椅子一万多。跟国产品牌相比呢? 本人严重颈椎病,脖子很容易不舒服 公司里全是 Aeron ,坐着确实舒服,不过,对你的颈椎病无效,这东西只是个椅子,不是…