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

mysql varchar类型字段为数字,不带引号查询查询结果与事实不符

背景 今天出现了一个bug,在数据库中我们将订单表中的order_no从之前的bigint(20)改成varchar(20)后,原有的代码逻辑在进行时查询,之前是以Long类型传参查询的。...select * from order_main where order_no=16541913435669023 debug的时候发现这条sql语句查询出来两条数据,另外一条毫不相关的订单也被查出来了...但是同样的sql我们放到数据库中确是只能查到一条数据。...根源 mysql5.7 查询varchar类型的数据,不加引号,触发隐式转换导致的查询结果错误。...、in参数包含多个类型、字符集类型或校对规则不一致等 隐式类型转换可能导致无法使用索引、查询结果不准确等,因此在使用时必须仔细甄别 数字类型的建议在字段定义就定义为int或者bigint,表关联关联字段必须保持类型

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

mysql alter 修改字段类型_Mysql必读mysql 增加修改字段类型及删除字段类型「建议收藏」

MysqL必读MysqL 增加修改字段类型及删除字段类型》要点: 本文介绍了MysqL必读MysqL 增加修改字段类型及删除字段类型,希望对您有用。如果有疑问,可以联系我们。...添加) 增加一个新列 alter table t2 add d timestamp; alter table infos add ex tinyint not null default ‘0’;//删除列...(字段名1[,字段名2 …]); MysqL> alter table tablename add index emp_name (name);加主关键字的索引 MysqL> alter table...field_type;修改原字段名称及类型: MysqL> ALTER TABLE table_name CHANGE old_field_name new_field_name field_type...;删除字段MysqL> ALTER TABLE table_name DROP field_name; 总结 如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

10.1K10

查询请求增加,如何做主从分离?

依据一些云厂商的 Benchmark 的结果,在 4 核 8G 的机器上运行 MySQL 5.7 ,大概可以支撑 500 的 TPS 和 10000 的 QPS。...这时,运营负责人说正在准备双十一活动,并且公司层面会继续投入资金在全渠道进行推广,这无疑会引发查询量骤然增加的问题。那么当查询请求增加,应该如何做主从分离来解决问题。...主从复制 MySQL 的主从复制是依赖于 binlog 的,也就是记录 MySQL 上的所有变化并以二进制形式保存在磁盘上二进制日志文件。...你可以在发送消息队列不仅仅发送微博 ID,而是发送队列处理机需要的所有微博信息,借此避免从数据库中重新查询数据。 第二种方案是使用缓存。...有时候我们遇到从数据库中获取不到信息的诡异问题,会纠结于代码中是否有一些逻辑会把之前写入的内容删除,但是你又会发现,过了一段时间再去查询又可以读到数据了,这基本上就是主从延迟在作怪。

40930

mysql已存在的表增加自增字段

需求: 已有的mysql数据表,希望增加一个自增的字段,并设置新数据的初始值。 实际上不复杂,只是做个备忘。...DEFAULT CHARSET=utf8; 测试数据: INSERT INTO `t_abc` (`name`) VALUES ('mike'), ('tom'), ('jack'); 添加自增字段并设置...新数据的起始值 /*增加一个自增主键字段,分两步操作*/ /*首先增加自增字段*/ alter table t_abc add column id int auto_increment primary...key; /*执行完上面这一条,字段增加,但值为空*/ /*执行这一条,它会自动为已存在的数据的自增字段赋初值,从1开始,同时将后续新增的数据从100开始*/ alter table t_abc auto_increment...1开始的初始值,其实隐含的设置当前表自增字段从1开始*/ alter table t_abc auto_increment; /*将所有数据增加10000*/ update t_abc set id=

10.8K10

mysql修改、增加、删除字段名等命令

Mysql 一、.mysql修改 1.修改字段类型、字段名、字段注释、字段默认值 #修改字段类型、字段注释、字段默认值 ALTER TABLE 表名 MODIFY [COLUMN] 字段名 新数据类型...mysql修改字段名: ALTER TABLE 表名 CHANGE [column] 旧字段名 新字段名 新数据类型; alter table table1 change column1 column1...box add column boxroom varchar(30) not null comment '座位空间' after boxname 6.增加一个字段 ALTER TABLE 表名 ADD...COLUMN newname 数据类型 数据长度 默认值 注释 //增加一个字段,默认为空 alter table box add column boxroom int 10 default null...comment '座位空间' //增加一个字段,默认不为空 alter table box add column boxroom int 10 not null comment '座位空间' 7.删除字段

1K20

Mysql中用SQL增加、删除字段,修改字段名、字段类型、注释,调整字段顺序总结

1.增加一个字段 代码如下 复制代码 //增加一个字段,默认为空alter table user add COLUMN new1 VARCHAR(20) DEFAULT NULL; //增加一个字段,...方法二 mysql 批量为表添加多个字段 alter table 表名 add (字段1 类型(长度),字段2 类型(长度),字段3 类型(长度)); 代码如下 复制代码 alter table em_day_data...table 表 change 修改前字段名 修改后字段名称 int(11) not null, change 修改前字段名 修改后字段名称 int(11) not null, change 修改前字段名...修改后字段名称 int(11) not null, change 修改前字段名 修改后字段名称 int(11) not null, change 修改前字段名 修改后字段名称 int(11) not...: alter table 表名 change 字段名 新字段字段类型 默认值 after 字段名(跳到哪个字段之后) 例子: 代码如下 复制代码 alter table appstore_souapp_app_androidmarket

4.6K30

查询 MySQL 字段注释的 5 种方法!

很多场景下,我们需要查看 MySQL 中表注释,或者是某张表下所有字段的注释,所以本文就来盘点和对比一下查询注释的几种方式。 创建测试数据库 开始之前咱们先创建一个数据库,以备下面演示使用。...字段注释查询方式1 查询语法如下: show full columns from 表名; 案例:查询 student 表中所有字段的注释信息: show full columns from student...; 执行结果如下图所示: 字段注释查询方式2 查询语法如下: select COLUMN_NAME 字段名,column_comment 字段说明,column_type 字段类型, column_key...where table_schema='test2022' and table_name='student'; 执行结果如下图所示: 字段注释查询方式3 查询表的 DDL(数据定义语言)也可以看到字段的注释内容...字段注释查询方式5 在 Navicat 中查看表的 DDL 语句也可以看到字段注释,选中表再点击右下脚“显示右边窗口”选项,然后再点击 DDL 就可以显示了,具体操作步骤如下图所示: 修改表注释和字段注释

5.1K30

mysql字段关键词模糊查询

CONCAT(applicationCode, clinicItemDictCode) LIKE '%003%' 总结: select * from Table_Name where concat(字段...1, '分隔符', 字段2, '分隔符', ...字段n) like '%关键字1%' and concat(字段1, '分隔符', 字段2, '分隔符', ...字段n) like '%关键字2%'...的作用是连接字符串,但这样有一个问题:如果你输入单个关键字“001003”也会查到数据,这并不是我们需要的结果, 解决方法是:由于使用逗号分隔多个关键字,说明逗号永远不会成为关键字的一部分,所以我们在连接字符串把每个字段以逗号分隔即可解决此问题...,下面这个sql语句不会查询到数据: SELECT * FROM tbl_app_clinic_item WHERE CONCAT(applicationCode, ',', clinicItemDictCode...这样有个问题,如果这两个字段中有值为NULL,则返回的也是NULL,即将表格中数据的appl那么这一条记录可能就会被错过,对此,我们可以使用IFNULL函数。

4K10

MySQL|查询字段数量多少对查询效率的影响

通过 select 字段构建 readset(MySQL 层) 首先需要构建一个叫做 read_set 的位图,来表示访问的字段位置及数量。...初次访问定位的时候还会构建一个模板(mysql_row_templ_t)(Innodb 层) 本模板主要用于当 Innodb 层数据到 MySQL 层做转换的时候使用,其中记录了使用的字段数量、字段的字符集...然后在这个循环下面会调用 row_sel_store_mysql_field_func 然后调用 row_sel_field_store_in_mysql_format_func 将字段一个一个转换为...到这里我们大概知道了,查询字段越多那么这里转换的过程越长,并且这里都是实际的内存拷贝,而非指针指向。...中为 '1' 的位数越多 建立的模板不同,字段越多模板数量越多 每行数据转换为 MySQL 格式的时候不同,字段越多模板越多,那么循环转换每个字段的循环次数也就越多,并且这是每行都要处理的。

5.6K20

MySQL 8.0.19亿级数据如何秒速增加字段

概述 今天主要介绍一下MySQL 8.0.19 instant add column的新特性,基于亿级数据秒速增加字段,下面一起来看看吧~ ---- 一、MySQL DDL 的方法 MySQL 在大型表上的...MySQL 使用 inplace 算法,会自动判断,能使用 not-rebuild-table 的情况下会尽量使用,不能的时候才会使用 rebuild-table。...如果涉及到修改数据(例如增加列),不关心主从同步延时的情况下使用默认的 inplace 算法,关心主从同步延时的情况下使用 gh-ost 如果使用的是 MySQL 8.0,推荐使用 MySQL 默认的算法设置...---- 三、mysql 8.0特性instant add column 1、instant add column原理 mysql数据库针对亿级别的大表加字段是痛苦的,需要对表进行重建,MySQL 5.7...2.2、添加字段 mysql 5.7 用inplace算法去对一亿的表添加字段,耗时接近10分钟,MySQL8.0 用instant算法对一亿的表添加字段,耗时0.12s --指定InPlace算法添加列

5.2K10

mysql longtext_MySql中LongText类型大字段查询优化

在本次项目表结构中,有一个longtext字段,用于存储长文本,仅万条数据,InnoDB存储文件就达G级,由于是一个小项目,受限于服务器与运维人员水平,不适合使用hdfs,MongoDB等拓展技术栈来解决这种问题...,因此直接对mysql存储进行优化,快速解决,利于维护。...涉及mysql基础知识 一、innodb存储引擎的处理方式 1.mysql在操作数据的时候,以page为单位 不管是更新,插入,删除一行数据,都需要将那行数据所在的page读到内存中,然后在进行操作,这样就存在一个命中率的问题...树底层的叶子节点为一双向链表,因此每个页中至少应该有两行记录,这就决定了innodb在存储一行数据的时候不能够超过8k,但事实上应该更小,有一些InnoDB内部数据结构要存储以及预留操作空间, 3.blob,text大字段

3.7K20
领券