首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

粗聊Mysql——你会表么?

本文中说到的“”,并非单纯的一个库,或是一张表,而是你建好的库和表在项目的运营中,是否能应付各种事件,下面我说说几个我在项目中遇到的问题以及处理的方法,算是一个小小的心得,给大家分享下。...这样就会造成一种情况,如果那天对数据库进行优化,把主键进行了重新排序(暂时没有找到mysql优化软件会优化主键,但是可以通过代码删除主键,然后从新建立自增主键来实现主键重新排序),那就彻底杯具了,栏目和文章完全对不上号了...所以我建议两表之间关联不用主键,而是单独一个编号的字段,我们这里可以用mysql的uuid()函数做为编号,相关文献可以参考《UUID做主键好还是不好》,只所以一张表要2个主键,一个物理主键(自增id...至于性能,我本地测了下基本上没差异,网上也有人做了10W条数据的测试——《实测MYSQL UUID性能》。...所以我建议,既然定义为varchar,就代表不会涉及到计算,何不干脆定义一个通用的长度,比如varchar(50),如果真要限制长度,用程序去判断,不要让数据库来限制,不然用户输了一长串,结果mysql

5.2K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL 系列教程之(五)DDL 操作:

    MySQL 数据库 创建数据库 使用root登录后,可以使用 create database if not exists user default charset utf8 创建数据库,该命令的作用:...创建RUNOOB数据库,并设定编码集为utf8 删除数据库 删库有风险,动手需谨慎 drop database 库名; MySQL 数据表 创建MySQL数据表需要以下信息: 表名 表字段名 定义每个表字段...MySQL数据表。...查看表结构 desc stu; 查看表语句 show create table stu\G 修改表结构 格式: alter table 表名 action(更改选项); 添加字段: 添加字段:alter...删除表 MySQL中删除数据表是非常容易操作的, 但是你再进行删除表操作时要非常小心,因为执行删除命令后所有数据都会消失。 DROP TABLE table_name ;

    7.7K73

    MySQL表语句转PostgreSQL表语句全纪录

    个人习惯用MySQL workbench EER数据建模,然后生成SQL语句到数据库中执行,这样表之间的关系比较直观。 像下面这样: 画图 ? 正向工程,生成DDL语句: ?...前两天接了个新需求,于是我依然使用MySQL workbench EER建模,结果好不容易建模完成了,却被告知这个项目用的数据库是PostgreSQL!...依然用MySQL workbench导出DDL,然后自己将MySQL DDL转换成PostgreSQL DDL。 我选择了自己转换SQL语句。...于是上万能的GayHub搜了下,还真有,列出来: mysql-to-postgres:https://github.com/maxlapshin/mysql2postgres mysql-postgresql-converter...{ public static void main(String[] args) throws IOException, JSQLParserException { // 你的MySQL

    3.1K20

    hive表语句转mysql

    从Hive表语句到MySQL的转换起因在数据处理和数据仓库建设中,常常会用到Hive进行数据存储和查询。然而,有时候我们需要将Hive中的表结构迁移到其他关系型数据库,比如MySQL。...本文将介绍如何将Hive中的表语句转换为MySQL中的表语句,方便数据迁移和数据同步。...表语句接下来,我们将上述Hive表语句转换为MySQL表语句:sqlCopy codeCREATE TABLE employee ( emp_id INT, emp_name VARCHAR...表语句现在我们将上述Hive表语句转换为适用于MySQL数据库的表语句:sqlCopy codeCREATE TABLE employee ( emp_id INT, emp_name...总结通过以上转换,我们成功地将Hive表语句转换为适用于MySQL表语句。在实际工作中,我们可以根据具体需求灵活调整转换规则,确保数据迁移和数据同步的顺利进行。

    28410

    MySQL表数据类型的选择

    如果查询中包含可为 NULL 的列,对 MySQL 来说更难优化,因为可为 NULL 的列使得索引、索引统计和值比较都更复杂。特别是计划在列上索引,就应该尽量避免设计成可为 NULL 的列。...MySQL 可以为整数类型指定宽度,例如 int(11),对大多数应用这是没有意义的:它不会限制值的合法范围,只是规定了 MySQL 的一些交互工具(例如 MySQL 命令行客户端)用来显示字符的个数。...MySQL 浮点型和定点型可以用类型名称后加(M,D)来表示,M 表示该值的总共长度,D 表示小数点后面的长度。...char 类型是定长的:MySQL 总是根据定义的字符串长度分配足够的空间。 char 存储会删除存储数据的末尾空格;varchar 不会。...与其它类型不同,MySQL 把每个 blob 和 text 值当作一个独立的对象处理。

    5.2K10
    领券