首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

粗聊Mysql——你会么?

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

5.2K10

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

创建RUNOOB数据库,并设定编码集为utf8 删除数据库 删库有风险,动手需谨慎 drop database 库名; MySQL 数据 创建MySQL数据需要以下信息: 名 表字段名 定义每个表字段...MySQL数据。...查看表结构 desc stu; 查看表语句 show create table stu\G 修改结构 格式: alter table 名 action(更改选项); 添加字段: 添加字段:alter...AUTO_INCREMENT=1 更改类型: ALTER TABLE 名称 ENGINE="InnoDB" 关于类型 MySQL数据库中的类型一般常用两种:MyISAM和InnoDB 区别:...删除 MySQL中删除数据是非常容易操作的, 但是你再进行删除操作要非常小心,因为执行删除命令后所有数据都会消失。 DROP TABLE table_name ;

7.6K73

mysql常见的选项和约束

create table选项 指定列选项:default 当插入一个新行到中并且没有给该列明确赋值,如果定义了列的默认值,将自动得到默认值 ;如果没有,则为null。...约束主要是防止非法数据进入中,保证数据的正确性和一致性,统称为数据完整性 约束也可以防止一个被删除 MySQL的约束保存在information_schema.table_constraints中...) 在定义外键约束,可以通过使用on delete cascade或on delete set null来改变外加的默认删除规则 on delete cascade:级联删除,当删除父中的行时,如果子表中有依赖于被删除父行的子行存在...,那么联通子行一删除,相当于rm -f on delete set null:当删除父中的行时,如果子表中有依赖于被删除的父行的子行存在,那么不删除,而是将子行的外键设置为null 外键引用定义...Oracle中国可以使用check约束,有相应作用 mysql> create table test_ck( -> id int check(id>0) -> ); mysql

12810

MySQL数据类型的选择

更小的数据类型通常更快,因为它们占用更少的磁盘、内存和 CPU 缓存,并且处理需要的 CPU 周期也更少。 简单就好。简单数据类型的操作通常需要更少的 CPU 周期。...如果查询中包含可为 NULL 的列,对 MySQL 来说更难优化,因为可为 NULL 的列使得索引、索引统计和值比较都更复杂。特别是计划在列上索引,就应该尽量避免设计成可为 NULL 的列。...因为需要额外的空间和计算开销,所以应该尽量只在对小数进行精确计算才使用 decimal——例如存储财务数据。...枚举(enum)类型 MySQL 在内部会将每个值在列表中的位置保存为整数,并且在的 .frm 文件中保存 “数字-字符串” 映射关系的 “查找”。...(对于这点很多公司项目中是用整数存储,我也查了资料,使用整数的理由一般是日期比较,计算整数更好处理)

5.2K10

MySQL-复杂查询及条件-别名-多表查询-04

目录 基本查询语句及方法 测试数据创建 创建数据库与 插入表记录数据 数据展示 常见结果排版 另一种结果排版 \G 简单查询语句的书写与执行顺序 查询语句书写 执行顺序 科普-- 别名 写法 可以对字段做四则运算...,根据条件筛选数据 最后执行 select,来拿筛选出来的数据中的(某些,select 后面跟的字段名)字段 科普-- 别名 关键字 as 可以给别名 可以给查询出来的虚拟(查询结果)别名 可以给字段别名...可以给函数的结果取别名(max、min 等) 写法 要别名的对象 as 别名 或者 直接 要别名的对象 别名 不过尽量还是用as ,不用as 可能语义不明确 给函数结果别名 ... max(hire_date...给别名 select ... from emp as t1 .... 给查询出来的虚拟别名 ... (select * from emp) as t2 ......给字段别名 select name as '姓名', post '部门' from emp; ?

3.8K20

MySQL库、、增删改查语句Demo

本页目录 库语句 库 修改库字符集 指定库排序规则 当前库状态的表语句 删除库 Navicat编辑数据库执行的SQL 表语句 添加字段 修改 修改字段 修改表字符集、排序规则 截断 删除...添加索引 一直都是用MySQL可视化工具,几乎没碰过库、等语句了。...我们无法人为控制,只能库完毕后执行修改库字符集或者库前修改MySQL配置 CREATE DATABASE IF NOT EXISTS `school` DEFAULT CHARACTER SET...-- 查看表语句 SHOW CREATE DATABASE `school` 删除库 -- 删除数据库 DROP DATABASE `school名错误就无法删除了`; Navicat编辑数据库执行的...直接执行就行,没有参数 SELECT @@character_set_database, @@collation_database 表语句 添加字段 修改 修改字段 修改表字符集、排序规则 截断

5.1K40

MySQL数据库、优化、算法、分区分库分总结

主要原因有如下两点 (1)Mysql内存临时不支持TEXT、BLOB这样的大数据类型,如果查询中包含这样的数据,在排序等操作,就不能使用内存临时,必须使用磁盘临时进行。...什么情况下应不或少索引?...EXPLAIN 的查询结果还会告诉你你的索引主键被如何利用的,你的数据是如何被搜索和排序的 当只要一行数据使用limit 1,MySQL数据库引擎会在找到一条数据后停止搜索,而不是继续往后查少下一条符合记录的数据...对一个包含外键的InnoDB转为MYISAM会失败; InnoDB是聚集索引,数据文件是和索引绑在一的,必须要有主键,通过主键索引效率很高。...在where语句中包含分区条件,可以只扫描一个或多个分区来提高查询效率;涉及sum和count语句,也可以在多个分区上并行处理,最后汇总结果。 3、分区更容易维护。

5.3K31

一个MySQL需求的讨论和引导

首先对于这个的定义上,业务同学说是归属于状态,也就意味着中的每一个用户都有唯一的状态值对应,这个中存储的数据量会越来越大。...到了这里需求的方向其实就有了大的转折,这个按照目前的需求其实使用日志的模式要更好一些,比如表中的数据是按照如下的列表情况存储,以日期为维度进行存储。 ?...如果需要按照T+1的模式去处理未完成的数据,整个复杂度只针对某一天的执行索引扫描,不会对其他的产生关联影响,而如果按照日期为单存储,整个事情的自由度就更大了,按照state或者是pid的维度进行查询...各大平台都可以找到我 微信公众号:杨荣的学习笔记 Github:@jeanron100 CSDN:@jeanron100 知乎:@jeanron100 头条号:@杨荣的学习笔记 网易号:@杨荣的数据库笔记...大鱼号:@杨荣的数据库笔记 腾讯云+社区:@杨荣的学习笔记

2.7K20

Mysql中使用rule作为别名引发的语法错误

不可以使用rule作为别名 MySQL别名不能为"rule",因为"rule"是MySQL的保留关键字。...你可以使用其他名称作为别名,例如: SELECT * FROM your_table AS rule; 将"your_table"替换为你的名,将"rule"替换为你想要的别名。..."rule"是MySQL的保留关键字吗 在MySQL中,“rule”作为保留关键字,通常与“show”命令结合使用,用于查看数据库下逻辑的拆分情况。...具体来说,“show rule”用于查看数据库下每一个逻辑的拆分情况,而“show rule from tablename”则用于查看数据库下指定逻辑的拆分情况。...因此,如果您在命名数据库对象(如表名或列名)使用了“rule”,可能会导致SQL语句解析的冲突或混淆。

9010

hive并添加数据_hive和mysql的关系

在使用hive进行开发,我们往往需要获得一个已存在hive表语句(DDL),然而hive本身并没有提供这样一个工具。...要想还原DDL就必须从元数据入手,我们知道,hive的元数据并不存放在hdfs上,而是存放在传统的RDBMS中,典型的如mysql,derby等,这里我们以mysql为元数据库,结合0.4.2版本的...连接上mysql后可以看到hive元数据对应的约有20个,其中和结构信息有关的有9张,其余的10多张或为空,或只有简单的几条记录,以下是部分主要的简要说明。...类的对应关系,如’org.apache.hadoop.hive.metastore.model.MTable’, ‘`TBLS`’,说明MTable类对应了元数据的TBLS,不难想象当我们创建一张...有了上面的信息,再想获得hive的表语句已经是易如反掌了,这里提供一个已经开发好的脚本,使用shell开发,大家可以自由修改。注意:其中mysql连接信息请根据实际环境进行配置。

2.8K30

深入浅出MySQL:从零开始掌握规约

hello,大家好,我是千羽 MySQL 是一款广泛使用的开源数据库管理系统,它以高性能、易用性和稳定性而著称。无论是初创公司还是大型企业,都依赖 MySQL 来管理和存储数据。...对于初学者来说,了解并掌握 MySQL 的基本规约是至关重要的,它不仅能够帮助你建立高效、可靠的数据库结构,还能为你未来的数据管理工作打下坚实的基础。 一、为什么需要规约?...在开始详细介绍 MySQL规约之前,我们需要先了解为什么需要遵循这些规约。以下是几个关键原因: 统一规范:有助于团队协作,确保代码和数据库结构的一致性和可读性。...必备三字段 【强制】 必备三字段:id, gmt_create, gmt_modified。 说明:其中 id 必为主键,类型为 unsigned bigint、单自增、步长为 1。...分库分策略 【推荐】 单行数超过 500 万行或者单容量超过 2GB,才推荐进行分库分。 说明:如果预计三年后的数据量根本达不到这个级别,请不要在创建就分库分。 15.

6110
领券