【MySQL】90% 开发者都踩过的坑:数据库数据类型选错有多可怕?

【MySQL】90% 开发者都踩过的坑:数据库数据类型选错有多可怕?

一、数据类型分类

二、数值类型

注意:bit 类型:

三、float 类型

float[(m,d)][unsigned]:M指定显示长度,d指定小数位数,占用空间4个字节。

小数:float(4,2)表示的范围是-99.99~99.99,MySQL在保存值时会进行四舍五入。

三、decimal 类型

decimal(m,d)[unsigned]:定点数m指定长度,d表示小数点的位数。

decimal(5,2)表示的范围是-999.99~999.99

decimal(5,2)unsigned 表示的范围0~999.99

decimal和float很像,但是有区别:float和decimal表示的精度不一样

说明:float表示的精度大约是7位。

decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0,如果m被省略,默认是10。

建议:如果希望小数的精度高,推荐使用decimal。

四、char 类型

char(L):固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255

五、varchar 类型

varchar(L):可变长度字符串,L表示字符长度,最大长度65535个字节。

关于varchar(len),len到底是多大,这个len值,和表的编码密切相关:

varchar长度可以指定为0到65535之间的值,但是有1-3个字节用于记录数据大小,所以说有效字节数是65532。

当我们的表的编码是utf8时,varchar(n)的参数n最大值是65532/3=21844[因为utf中,一个字符占用3个字节),如果编码是gbk,varchar(n)的参数n最大是65532/2=32766(因为gbk中,一个字符占用2字节)。

char 和 varchar 比较:

如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5

如果数据长度有变化,就使用变长(varchar),比如:名字,地址,但是你要保证最长的能存的进去。

定长的磁盘空间比较浪费,但是效率高。

变长的磁盘空间比较节省,但是效率低。

定长的意义是,直接开辟好对应的空间。

变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。

六、日期和时间类型

date:日期'yyyy-mm-dd',占用三字节

datetime 时间日期格式'yyyy-mm-dd HH:ii:ss'表示范围从1000到9999,占用八字节

timestamp:时间戳,从1970年开始的 yyyy-mm-dd HH:ii:ss格式和datetime完全一致,占用四字节

1)更改表中变量的值

七、枚举 enum 和 set 集合

enum:枚举,“单选”类型;

enum('选项1,选项2','选项31,…);

该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,3,…….最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。

set:集合,“多选”类型;set('选项值11,选项值2,选项值31,…);

该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,……最多64个。

说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。

1)按条件来查找信息

Read more

打造炫酷 GitHub 个人主页:保姆级美化教程

打造炫酷 GitHub 个人主页:保姆级美化教程

打造炫酷 GitHub 个人主页:保姆级美化教程 在这个“颜值即正义”的时代,GitHub 主页不仅仅是代码仓库,更是程序员的“第二张简历”。一个美观的个人主页能让访问者眼前一亮,快速了解你的技术栈和个性。 这里先放出我的个人主页作为演示:https://github.com/youlai-code 今天就手把手教大家如何解锁 GitHub 的隐藏功能,定制专属的个人展示页! 🛠 第一步:解锁“同名仓库” 这是 GitHub 的一个彩蛋功能。你需要创建一个与你用户名完全一致的仓库。 1. 登录 GitHub,点击右上角的 + 号,选择 New repository。 2. 关键点:仓库名(Repository name)必须和你的 Owner(用户名) 保持完全一致。 * 例如:我的用户名是 youlai-code,那么仓库名也必须填

By Ne0inhk
如何在VsCode中使用git(免敲命令版本!保姆级!建议收藏!)

如何在VsCode中使用git(免敲命令版本!保姆级!建议收藏!)

目录 文章目录 前言 一、电脑安装git 二、在vscode安装git插件 三、克隆仓库 四、提交代码 五、创建分支、切换分支、合并分支 1、创建分支 2、切换分支 3、合并分支 六、创建标签和推送标签 七、解决冲突 八、拉取、抓取仓库 九、Reivew代码 总结 前言 随着Vscode的推出和普及,Git的使用也发生了变化,从原来的命令行管理仓库,再到现在用vscode从提交代码、解决冲突、reivew代码,整个管理仓库的过程全部都是可视化,大大降低了新手的使用难度,让新手也能轻松使用git 一、电脑安装git git官网:Git - 安装 Git 安装完git后,打开vscode显示这样的界面就是安装成功了

By Ne0inhk
开源杀疯了!Qwen3.5 Plus + OpenClaw,性能对标GPT-5.2还免费商用

开源杀疯了!Qwen3.5 Plus + OpenClaw,性能对标GPT-5.2还免费商用

文章目录 * 一、先唠明白:Qwen3.5 Plus到底是什么来头 * 二、OpenClaw:给大模型装个「万能插件底座」 * 三、实测对比:凭什么说对标GPT-5.2? * 四、零门槛上手:5行代码调用Qwen3.5 Plus * 五、OpenClaw集成:让大模型更听话、更能打 * 六、本地部署方案:离线也能用,隐私拉满 * 七、商用无忧:开源授权+免费额度全解析 * 八、常见问题踩坑指南 目前国内还是很缺AI人才的,希望更多人能真正加入到AI行业,共同促进行业进步,增强我国的AI竞争力。想要系统学习AI知识的朋友可以看看我精心打磨的教程 http://blog.ZEEKLOG.net/jiangjunshow,教程通俗易懂,高中生都能看懂,还有各种段子风趣幽默,从深度学习基础原理到各领域实战应用都有讲解,我22年的AI积累全在里面了。注意,教程仅限真正想入门AI的朋友,

By Ne0inhk

从GitHub星标到生产环境:热门开源项目的落地挑战

从GitHub星标到生产环境:热门开源项目的落地挑战 引言:当明星项目遇见真实场景 在AI生成内容(AIGC)领域,Image-to-Video图像转视频生成器自发布以来迅速成为GitHub上的高星项目。其基于I2VGen-XL模型的架构,能够将静态图片转化为具有动态效果的短视频,在社交媒体、广告创意和影视预演等场景中展现出巨大潜力。 然而,一个项目从“能跑”到“可用”,再到“可量产”,中间存在巨大的工程鸿沟。本文将以科哥团队对Image-to-Video的二次构建开发实践为案例,深入剖析如何将一个热门开源AI项目从演示原型推进至准生产级应用,并总结出一套可复用的技术迁移方法论。 一、技术原理解析:I2VGen-XL的核心机制 核心架构与工作流程 Image-to-Video依赖于I2VGen-XL这一扩散模型变体,它结合了图像编码器、时间注意力模块和视频解码器三大组件: 1. 图像编码阶段 输入图像通过CLIP-ViT或类似视觉编码器提取语义特征向量。 2. 时序建模阶段 利用3D U-Net结构中的时空注意力机制,在潜在空间中引入帧间一致性约束

By Ne0inhk