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

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

需求: 已有的mysql数据表,希望增加一个自增的字段,并设置新数据的初始值。 实际上不复杂,只是做个备忘。...CHARSET=utf8; 测试数据: INSERT INTO `t_abc` (`name`) VALUES ('mike'), ('tom'), ('jack'); 添加自增字段并设置新数据的起始值...alter table t_abc add column id int auto_increment primary key; /*执行完上面这一条,字段增加,但值为空*/ /*执行这一条,它会自动为已存在的数据的自增字段赋初值...*/ alter table t_abc add column id int auto_increment primary key; /*这里没有指定任何数值,执行完后只为自增字段赋从1开始的初始值...; /* 前面的100 我们是任意指定的,现在我们应该指定数据库中的maxId+1作为下一个数据的起始值*/ set @maxId=1; select max(id) into @maxId from

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

    MySQL数据库的查询

    左连接以左表为主根据条件查询右表数据,右表数据不存在使用null值填充。...右连接以右表为主根据条件查询左表数据,左表数据不存在使用null值填充。...主查询和子查询的关系: 子查询是嵌入到主查询中 子查询是辅助主查询的,要么充当条件,要么充当数据源 子查询是可以独立存在的语句,是一条完整的 select 语句 2、子查询的使用 例1....); 3、小结 子查询是一个完整的SQL语句,子查询被嵌入到一对小括号里面 数据库设计之三范式 1、数据库设计之三范式的介绍 范式: 对设计数据库提出的一些规范,目前有迹可寻的共有8种范式,一般遵守3范式即可...第三范式(3NF): 满足 2NF,另外非主键列必须直接依赖于主键,不能存在传递依赖。即不能存在:非主键列 A 依赖于非主键列 B,非主键列 B 依赖于主键的情况。

    18.5K30

    mysql longtext 查询_mysql中longtext存在大量数据时,会导致查询很慢?

    使用explain: 有content时结果: mysql> explain select id, name, last_update_time from t order by last_update_time...无content的时候,查询走的是idx_last_update_time,我猜测这个索引中包含了id,name字段,因此仅通过索引就可以获取到所需的数据,因此速度很快。...建议改写sql语句,让数据库的执行计划更充分使用索引,假设id是主键: select id, name, content from t where id in ( select id from t order...我觉得,主要跟你的分页查询的方式有关,limit 10000,10 这个意思是扫描满足条件的10010条数据,扔掉前面的10000行,返回最后的10行,在加上你的表中有个,非常大的字段,这样必然增加数据库查询的...i/o时间, 查询优化你可以参照 @邢爱明 的 SELECT id,title,content FROM items WHERE id IN (SELECT id FROM items ORDER BY

    4.1K20

    msyql查询数据库中不存在的记录

    背景 有时候,需要往数据库里插入数据,这些数据,有些已经在MySQL中。但这种导入的工作,只是临时性的,又想专门写一个脚本去判断是否存在数据库,不存在就插入。...这里提供一个骚操作,可以直接用MySQL查看哪些不在数据库的,然后再插入。...| 1 | zhangsan | | 2 | wangwu | | 3 | zhaoliu | +----+----------+ 3 rows in set (0.00 sec) 查看存在的数据...你可以使用以下查询语句来判断 "zhangsan" 和 "lisi" 是否在数据库中.如果 "zhangsan" 和 "lisi" 存在于数据库中,那么可以查询将返回它们的名字。...如果你想知道哪个名字不在数据库中,可以稍作修改,使用 NOT IN 来找出不在数据库中的名字 SELECT 'zhangsan' AS name WHERE 'zhangsan' NOT IN (SELECT

    27930

    【MySQL数据库】详细讲解MySQL的查询

    图片多表查询⭐多表关系在项目开发中,在进行数据库表结构设计时,会根据业务需求以及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在各种联系,基本分为以下三种一对多(多对一...varchar(10) comment '课程名称') comment '课程表';​insert into course values (null,'java'),(null,'php'),(null,'mysql...原来的表 图片联合查询对于联合查询(union),就是把多次查询的结果合并起来,形成一个新的查询结果集查询到的多张表的列数要保持一致,而且字段列表也要保持一致select 字段列表 from 表A……...的地方都可以使用anyall子查询返回列表的所有值都必须满足行子查询子查询返回的是一行(可以是多列) 常用操作符:= in ,not in 图片表子查询子查询返回的是多行多列 常用运算符:in 图片如果大家有不明白的地方...,或者文章有问题,欢迎大家在评论区讨论,指正我正在参与 腾讯云开发者社区数据库专题有奖征文。

    26840

    mysql数据库中查询数据的语句怎么写_mysql数据库多表查询

    命令:mysql>select id, Sum(score) from result group by id; 多表查询 一、等值查询 现在有两个表: 现在要查询年龄小于20岁学生的不及格成绩...left join (select id, score from result where score < 60) b (过滤右表信息) on a.id = b.id; 左外连接就是左表过滤的结果必须全部存在...如果存在左表中过滤出来的数据,右表没有匹配上,这样的话右表就会出现NULL; (2)右外连接查询 select a.id,score from (select id,age from stu where...如图: 我们发现过滤出来的表进行的匹配只有两条满足条件(红色代表条件满足),但最后的结果却是: 左表不匹配的数据改为空,右表过滤出来的数据都要存在。...(3)全外连接查询 结合了左外连接和右外连接,使得左表和右表的数据都存在。

    29.9K20

    oracle数据库查询语句大全_oracle查询是否存在记录

    1 oracle数据库查询表的所有数据–select * from 表名;(* 代表所有) 2 oracle数据库查询表中指定字段的值–select 字段名1,字段名2,……from 表名; 3 oracle...数据库往表中添加数据信息–(添加信息使用insert into语句) insert into 表名 values(添加相对应的数据信息,如果在一个字段名中没有信息可以用“null”null的意思是空白...); 填写完数据后执行就把你想加入的数据信息添加到表中了,这时信息并没有添加到数据库里而是只在表面添加完毕,之后还要执行一个命令–commit;(commit它在数据库里的意思是数据提交的意思)。...你在填写完数据信息后也可以不用写这个命令,直接点击左上角一个向下的绿色箭头就可以也是提交的意思。...有填写数据就有删除数据,而删除表中数据信息的语句就是delete from 表名 where 字段名=想删除表中的数据信息; 4 oracle数据库给查询结果中的字段名使用别名。

    1.1K20

    Mysql数据库-子查询

    Mysql数据库-子查询 1. 什么是子查询 # 子查询定义 ## B语句作为A语句的一部分,B语句是select查询语句,那么B语句称之为子查询,内层查询(子集,subquery) -- 1....查询emp表的最高工资salary,然后再根据最高工资salary查询员工的信息 -- 2.1 通过max(salary)可以查询出emp表的最高工资为9000 mysql> select max(salary...查询工资大于5000的员工,来自于哪些部门的名字 -- 1.1 首先查询salary>5000的部门ID,列子查询(多行单列) mysql> select dept_id from emp where...> -- 子查询有结果返回1(相当于true) select exists(select * from emp where salary > 1000); -- 执行如下:可以从表的数据来看,存在salary...> -- 子查询没有结果返回0(相当于false) select exists(select * from emp where salary > 10000); -- 执行如下:可以从结果看到,不存在

    45.5K10

    MYSQL数据库-复合查询

    MYSQL数据库-复合查询 零、前言 一、基本查询 二、多表查询 三、自连接 四、子查询 1、单行子查询 2、多行子查询 3、多列子查询 3、在from子句中使用子查询 五、合并查询 1、union 2...、union all 零、前言 本章主要讲解学习MYSQL数据库中的复合查询,前面我们讲解的mysql表的查询都是对一张表进行查询,在实际开发中这远远不够 一、基本查询 示例: 查询工资高于500...worker,给自己的表起别名,因为要先做笛卡尔积,所以别名可以先识别 四、子查询 子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询 1、单行子查询 返回一行记录的子查询...:显示工资比部门30的所有员工的工资高的员工的姓名、工资和部门号 any关键字:显示工资比部门30的任意员工的工资高的员工的姓名、工资和部门号(包含自己部门的员工) 3、多列子查询 单行子查询是指子查询只返回单列...,单行数据;多行子查询是指返回单列多行数据,都是针对单列而言的,而多列子查询则是指查询返回多个列数据的子查询语句 示例:查询和SMITH的部门和岗位完全相同的所有雇员,不含SMITH本人 3、在from

    13.2K30

    【数据库】MySQL查询优化

    MySQL发送查询请求,到底做了什么工作? 下图是MySQL查询执行流程图: ? •客户端发送一条查询给服务器。•服务器先检查查询缓存,如果命中了缓存,则立刻返回查询在缓存中的结果。...•服务端进行SQL解析、预处理、再由优化器生成对应的执行计划。•MySQL根据优化器生成的执行计划,调用存储引擎的API来执行查询。•将结果返回给客户端。 是什么导致MySQL查询变慢了?...对于MySQL,最简单的衡量查询开销的三个指标如下: •响应时间•扫描的行数•返回的行数 没有哪个指标能够完美地衡量查询的开销,但它们大致反映了MySQL在内部执行查询时需要访问多少数据,并可以大概推算出查询运行的时间...注:索引是要另开辟一块空间存储的,所以不能不要钱滴都加索引。 2.关联子查询 MySQL的子查询实现是非常糟糕的。...列表中的选项有专门的优化策略,一般会认为MySQL会先执行子查询返回所有包含author_id 为1的book_id。

    13.4K10

    MySQL数据库——连接查询

    概述: 连接查询的作用将多张表进行内容上的连接,查看数据时可以同时看到多张表的多个数据 连接查询的分类 内连接查询 左连接查询 右连接查询 自连接查询 语法 #内连接 SELECT * FROM...inner join 实现多表查询,查询共有记录。...SELECT * FROM 表1 inner join 表2 on 表1.字段=表2.字段 左连接查询 left join 以左表为主,查询右表的数据。若右表不存在数据,则返回null。...SELECT * FROM 表1 left join 表2 on 表1.字段=表2.字段 右连接查询 right join 以右表为主,查询左表的数据。若左表不存在数据,则返回null。...SELECT * FROM 表1 right join 表2 on 表1.字段=表2.字段 自连接查询 inner join 左表和右表是同一个表,查询两个表中的数据。

    53.8K85

    Mysql数据库--聚合查询、分组查询、联合查询(不同的连接方式)

    1.查询的进阶版 1.1查询搭配插入进行使用 我们首先创建两张表,一个叫做student,一个叫做student2,两个表都是只有这个int和varchar 的数据类型,这个时候,我们向这个第一个表里面直接使用这个...insert插入数据,但是这个时候student2这个表还是空的; 我们查询这个student这个表里面插入的内容: 把这个查询的结果直接插入到我们的这个student2这个表里面去:这个实际上就是把两个步骤合成了一步...,但是因为这个是查询结果的插入,所以就可以直接把两个语句合并了,查询发现这个是成功的; 但是上面的这个查询结果的直接插入显然是有局限性的,就是两个表的结构必须是一样的,否则这个插入注定无法成功,我们的两个表都是只有这个...id和name两列,因此这个是可以把我们查询到的结果直接插入的; 1.2聚合查询 聚合查询的这个里面主要就是我们的这个sum,count,min,max等等之类的这个函数的用法添加到了我们原来的这个语句里面去罢了...,因此这个count还是很有必要的; 我们不仅可以使用这个通配符(表示所有)作为我们的查询的内容,我们也可以使用这个name进行指定,反正我们这个表里面无论使用哪一个索引,查询出来的这个结果都是一样的;

    25410
    领券