collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准 现在创建一张表user1: mysql> create table if not exists user1(...affected (0.00 sec) mysql> 创建表user2: mysql> create table if not exists user2( -> id int, -...(0.03 sec) 存储引擎不同,此时我们查看user1和user2:建表的时候出现不同的个数 不同的存储引擎对于磁盘文件的个数要求是不一样的 查看表desc 查看当前数据库的位置:select...修改表alter 在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表。...xingming varchar(60) DEFAULT NULL; 向表中插入数据insert into values mysql> insert into user values (1,'张三
理解如何高效地插入数据是数据库操作的基本技能。 语法: 这是MySQL中 INSERT 语句的基本语法,用于向数据库表中插入数据。...各部分解释: INSERT INTO:表示插入数据到指定表。 table_name:指定要插入数据的表名。 (column1, column2, ...)...:可选部分,列出要插入数据的列名。如果省略列名,默认插入表中的所有列。 VALUES:后面跟随插入的值。每一组值对应表中的列。...示例: 全列插入 全列插入:所要插入的列可以省略不写,但是必须插入表的全部列。...各部分解释: SELECT:用于选择查询的数据。 DISTINCT(可选):如果指定了 DISTINCT,则只返回不同的(唯一的)结果。 *:表示选择所有列。
name = ‘孙悟空’;##### 将总成绩倒数前三的 3 位同学的数学成绩加上 30 分 (1)-- 查看原数据 – 别名可以在ORDER BY中使用 SELECT name, math...,自增 id 在原值上增长 查看表结构:SHOW CREATE TABLE for_delete_table\G 会有 AUTO_INCREMENT=n 项 截断表 (TRUNCATE [TABLE...] table_name) 只能对整表操作,不能像 DELETE 一样针对部分数据操作; 实际上 MySQL 不对数据操作,所以比 DELETE 更快,但是TRUNCATE在删除数据的时候,并不经过真正的事物...,所以无法回滚 会重置 AUTO_INCREMENT 项 插入查询结果 语法:INSERT INTO table_name [(column [, column …])] SELECT… 案例:删除表中的的重复复记录...表重命名为duplicate_table 聚合函数 expression:表达式,这里主要是指列名 函数 说明 COUNT([DISTINCT] expr) 返回查询到的数据的 数量 SUM([DISTINCT
数量必须和定义表的列的数量及顺序一致 INSERT INTO student VALUES (100, 10000, '唐三藏', NULL); INSERT INTO student VALUES...可能会影响到索引的使用 例如这里我们查询一下:student表中 id > 2的学生: 3.指定列查询: 指定列的顺序不需要按定义表的顺序来,这里我们查name和mail; 4...AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行的部分 8.2范围查询: BETWEEN ......AND, 查询分数在30到50的成绩 8.3模糊查询:LIKE % 匹配任意多个(包括 0 个)字符:查询带' 孙' 字的同学 匹配严格的一个任意字符:查询 "...例子:将孙悟空同学的数学成绩变更为 99 分 四.删除数据 语法: DELETE FROM 表名 [WHERE ...] [ORDER BY ...] [LIMIT ...]
表的增删改查 CRUD : Create(创建), Retrieve(读取),Update(更新),Delete(删除) 1.1 Create 语法: INSERT [INTO] table_name...-- 注意,这里在插入的时候,也可以不用指定id(当然,那时候就需要明确插入数据到那些列了),那么mysql会使用默认的值进行自增。...,但冲突数据的值和 update 的值相等 -- 1 row affected: 表中没有冲突数据,数据被插入 -- 2 row affected: 表中有冲突数据,并且数据已经被更新 -- 通过 MySQL...实际上 MySQL 不对数据操作,所以比 DELETE 更快,但是TRUNCATE在删除数据的时候,并不经过真正的事 物,所以无法回滚 3....去重表数据 创建一个结构一样的表 插入查询结果 重命名表名 聚合函数 统计总数(count) 查数学成绩有多少个 也可以重命名 统计不重复的数学成绩个数 先去重再统计 sum求和 数学成绩总和 统计平均分
affected: 表中有冲突数据,并且数据已经被更新 通过 MySQL 函数获取受到影响的数据行数: SELECT ROW_COUNT(); +-------------+ | ROW_COUNT()...例子一:删除孙悟空同学的考试成绩 也可以接order by,例如删除排名最后的一名: 例子二:删除整张表数据 注意:删除整表操作要慎用!!! 并且MySQL中,表分为表本身和表中的数据。...实际上 MySQL 不对数据操作,所以比 DELETE 更快,但是TRUNCATE在删除数据的时候,并不经过真正的事物,所以无法回滚 3....但是having与where是有区别的,不建议混用: 不要单纯的认为,只有磁盘上的表结构导入到mysql,真实存在的表,才叫做表。 中间筛选出来的,包括最终结果,在我看来,全部都是逻辑上的表!...“MySQL一切皆表”。 未来只要我们处理好单表的CURD,所有的sql场景,我们全部都能用统一的方式进行。
MySQL基本查询 表的增删改查:CRUD Create(创建)包含insert Retrieve(读取)包含select Update(更新) Delete(删除) 一.增加数据Create 主要是...左侧为表中属性,右侧为自定义插入的内容,左右两侧安装顺序是一一对应的,如果顺序不同就会导致类型不同而出错。...exam_math; 3.查询字段为表达式 在MySQL数据类型的介绍中,select可以执行相应的各种表达式,函数。...实际上 MySQL 不对数据操作,所以比 DELETE 更快,但是TRUNCATE在删除数据的时候,并不经过真正的事物,所以无法回滚。...都是对表进行各种的增删查改,尤其对于查找,表与表之间因外键的联系等。
MySQL表的增删改查(基础) 据库最主要的操作就是增(create)删(update)改(retrieve)查(delete)。(CURD) 注意:进行增删改查操作的时候,请务必选中数据库。...在MySQL中,当前一次插入一条记录,分10次插入,效率要远低于一次把10个记录一起插入。因为MySQL是一个“客户端服务器”结构的程序。 原因: 由于网络请求和响应的时间开销引起的。...但是要想能够描述“条件”现有一些“关系运算符”&“逻辑运算符” 由于SQL是一个比较老的数据库。所以其与Java中的很多运算符不同。...mysql支持的模糊匹配功能是非常有限的。但是在实际开发中,可能会遇到更加复杂的情况。于是发明了一个东西, 正则表达式,来描述这种字符串的规则的。...那么怎么做,才能保证数量可控呢?在查询操作中,引入了一个limit,通过limit来限制查询结果的数量。 直接在查询语句的末尾,加上limit指定N,N就表示这次查询结果的最大值。
当前表的字符集为 utf8,校验集为 utf8_general_ci,存储引擎为 InnoDB,这些都是数据库的 默认属性,只要我们在创建表时不指定属性,表就会继承数据库的默认属性 通过 InnoDB...引擎创建的表会生成 两个文件 注意: comment '内容' 表示注释,通常用来注明该字段的含义及用途 在 MySQL 中定义无符号类型的数据,需要把 unsigned 放在类型之后修饰 1.1.创建时指定属性...除了使用数据库的 默认属性,还可以在创建时指定属性,比如再创建一张 goods 表,表示商品信息,包含字段有 商品名、价格、数量、厂商,并且在创建表时,指定字符集为 gbk,校验集为 gdk_chinese_ci...,还需要进一步了解表的 结构 信息,比如有哪些字段,才能知道如何使用这张表,查看表的详细信息语法为 DESC tablename 分别查看刚才创建的两张表的 结构 信息 mysql> desc person...(a int, b int, c double); mysql> alter table person drop a, drop b, drop c; 刚刚新增的无用字段立马就被删除了 在 MySQL
CHECK - 保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略 CHECK子句。...,foreign key(classId) references class(id)); 再次往student中插入数据,就务必要确保插入的数据的classld的值,得在class表中存在....如果一个学生注册了多门课程,那么该学生的 student_id 将在 connect_student_course 表中多次出现,但每次都与不同的 course_id 关联。...表名1 right join 表名2 on 连接条件; 此时两个表的数据不是一一对应的,相应的外连接内连接就会产生不同的效果 内连接: 左外连接: 说明: 左外连接就是以左表为基准能够确保左表中的每个记录都出现在最终结果里...如果左表中的记录,在右表中没有对应的记录,此时就会把右表中的相关字段,填成 NULL 右外连接: 说明: 右外连接,是以右表为基准,然后确保右表中的每个记录都出现在最终结果里如果右表中的某个记录在左表里没有对应的相关字段
CHECK - 保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略CHECK子句。...,语法: foreign key (字段名) references 主表(列) 用例: -- 创建班级表,有使用MySQL关键字作为字段时,需要使用``来标识 DROP TABLE IF EXISTS...第三范式(2NF): 第三范式是在第二范式的基础上建立起来的,即满足第三范式必须先满足第二范式。第三范式要求一个数据表中每一列数据都和主键直接相关,而不能间接相关。...联合查询 实际开发中往往数据来自不同的表,所以需要多表联合查询。多表查询是对多张表的数据取笛卡尔积: ?...='英文') and cou.id = sco.course_id); 在from子句中使用子查询:子查询语句出现在from子句中。这里要用到数据查询的技巧,把一个子查询当做一个临时表使用。
注意: 实际开发中,大部分的表,一般都会带有一个主键,主键往往是一个整数表示的id 在mysql中,一个表里,只能有一个主键,不能有多个 虽然主键不能有多个,mysql允许把多个列放到一起共同作为一个主键...(id,name,username,password); 学生和账号在不同的表里,相互关联 student(studentId,name); account(accountId,username,password...针对这种关系: student(id,name); class(class,name,studentIds); 注意:这种在MySQL中不可行,因为MySQL中没有一个像数组这样的类型。...引入group by就可以针对不同的组来分别进行聚合。 如果不带聚合函数的普通查询,一般不能group by。mysql中如果没有order by,这里的顺序是不可预期的。...联合查询(多表查询) 实际开发中往往数据来自不同的表,所以需要多表联合查询。多表查询是对多张表的数据取笛卡尔积: 笛卡尔积是通过排列组合来的。 笛卡尔积得到一个更大的表。
数据库约束 在MySQL中,约束用于定义表中数据的规则,保证数据的一致性、完整性和准确性。以下是常见的数据库约束类型: NULL约束 NOT NULL:指示某列不能存储NULL值。...对于MySQL,它的使用并不会真正执行检查,只是语法上的支持。...表的设计 在数据库设计中,表之间的关系是至关重要的。MySQL支持一对一、一对多和多对多的关系。 一对一 每个记录只对应另一个表中的一条记录。...插入和查询搭配(进阶) 在MySQL中,通过INSERT语句插入数据是常见的操作,插入数据时可以使用SELECT来插入其他表的内容。 INSERT INTO 目标表名 (列名1, 列名2, ...)...FROM 表1 LEFT JOIN 表2 ON 表1.列名 = 表2.列名; 6.3 右连接(RIGHT JOIN) 右连接(也叫右外连接)与左连接类似,不同之处在于它返回右表中的所有记录,以及左表中匹配的记录
用例:创建一张学生表 -- 创建一张学生表 DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT, sn INT comment...VARCHAR(20) comment '姓名', qq_mail VARCHAR(20) comment 'QQ邮箱' ); 单行数据+全列插入 -- 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致...指定列查询 -- 指定列的顺序不需要按定义表的顺序来 SELECT id, name, math FROM exam_result; ?...AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行的部分 案例: ? BETWEEN a0 AND a1: ? IN: ? 模糊查询:LIKE ?...[LIMIT ...] -- 删除表中某一数据 DELETE FROM 数据表名 WHERE 条件; -- 删除整表数据 DELETE FROM 数据库名; ?
ALTER TABLE 旧表名 RENAME 新表名; 此语句可以修改表的名称,其实一般我们在终端中使用,有可视化工具完全没必要用命令。...增加字段 ALTER TABLE stu ADD demo VARCHAR(10) NOT NULL ; -- ALTER TABLE 表名 ADD 要加的字段名 数据类型 [属性(可不写)] ; 删除字段...result ADD CONSTRAINT FK_RESULT_STU FOREIGN KEY (studentNo) REFERENCES stu(studentNo); 看好我这个表,主键在stu...表里面,外键表是result,不要搞反了。...外键名规范是FK_表1_表2。 小知识 我们发现,我们上面的语句常用ALTER TABLE这个关键字。 我们可以常识查看帮助文档。 如果英语不咋地,就老老实实搜浏览器吧。
大写表示关键字; []表示可写可不写; 这里我们先学会一下查看表中的数据: 查看数据: select* from 表名 示例:查看courses表中的数据 我还未在select表中添加数据,所以显示为空...全列查询 在之前我们其实已经学会了全列查询也就是: select * from 表名; select和from表示关键词; * 表示要查询表中的所有列; 如果在生产环境中,查询表是一个很危险的操作...示例: mysql> select * from exam; +------+--------+---------+------+---------+ | id | name | chinese...示例: 注意: 指定列的顺序与表的顺序无关; 除表达式外,如果查找该表中不存在的字段名,那么就会报错; 为查询结果指定别名 语法: SELECT column [AS] alias_name...from 表名; 先查看一下表中的数据 示例: 接下来对chinese、math、english中的元素进行去重 如果我们要同时加上id,name并且对chinese、math、english中的元素进行去重
本篇是继上篇的下篇,如果上篇没有看过小伙伴,可以先看看我的上一篇再来看一下这一篇【MySQL】表的增删查改(CRUD)(上) 条件查询(where) 概念: 条件查询:允许用户在查询语句中指定筛选条件...,数据库中会根据这些条件从表中筛选出符合条件的数据,将满足条件的记录返回给用户,不满足的条件的排出在外。...这与MySQL执行SQL语句有关 执行顺序: 首先确定表,执行from; 查询的时候爸符合条件的数据过滤处理,也就是接下来执行where语句,此时where语句还没有被定义别名; 随后执行select...--查询英语成绩在60-90的同学(between a and b) mysql> select * from exam where english between 60 and 90; +-----...[LIMIT ...] update:表示制定要更新的表; set:用于指定要更新的列和新值,也可以更新多个列,用逗号隔开; where:可选句子,用于指定更新的条件。
以下是针对数据表中数据的增删查改。 2.增加数据 单行数据 + 全列插入 insert 数据表名 value (值1,值2,......,值n); 在插入数据时,插入的数据顺序必须与创建数据表时对应的字段位置顺序相同,不可搞乱顺序,规避数据顺序错误情况,总而言之要一一对应。...AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行的部分 3.MySQL不存在==这种运算符 4.like运算符的模糊匹配只适用于字符串。...查询语文成绩在 [80, 90] 分的同学及语文成绩 2....案例: 因为不存在== ,所以mysql这里的=既可以代表赋值,还可以代表是否相等。 5.删除数据 DELETE FROM table_name [WHERE ...]
大家好,又见面了,我是你们的朋友全栈君。...打开数据库: 步骤:新建查询(Ctrl+Q)→写SQL语句→运行→刷新→创建表成功 ①新建查询(Ctrl+Q) ②写SQL语句: 创建表的SQL语句一般格式: CREATE TABLE...表名>( [列级完整性约束定义] {, [列级完整性约束定义] … } [,表级完整性约束定义] ) 下面来举个列子来说明一下就更清晰了,比如我需要创建一个...tinyint, Sdept char(20) ) 顺便把图也附上: ③运行,然后刷新 最后运行,再刷新一下,表就出来了。...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
要查询 books 表中的所有内容,你可以使用以下 SQL 语句: USE bookmanagement; -- 选择数据库 SELECT * FROM books; -- 查询books表中的所有内容...如果你使用的是命令行界面 (mysql 客户端) 来操作数据库,可以直接在命令提示符中输入上述命令。...如果你使用的是图形界面的数据库管理工具(例如 MySQL Workbench, phpMyAdmin 等),你可以在SQL查询窗口或相应的位置执行这些命令。 这将显示 books 表中的所有行和列。...显示Empty set (0.00 sec) "Empty set" 表示 books 表中当前没有任何记录。换句话说,这个表是空的。...如果你预期 books 表中有数据,但却看到了 "Empty set",那么可能有以下原因: 数据尚未被添加到表中。 在某个时间点,数据可能已被删除。 可能连接到了错误的数据库或使用了不同的表。