MySQL数据库 | 数据表的增删改查
MySQL数据的增删改查(crud)
本文结构
一、增加 create
二、修改 update
三、查询 retrieve(简单查询,下篇详细展开)
四、删除 delete
首先,创建简单的classes数据表和略微复杂的students数据表(id name age gender cls_id birthday),以便接下来的操作。
create table classes
(
id int primary key auto_increment,
name varchar(20)
);
create table students
(
id int unsigned not null auto_increment primary key,
name varchar(20),
age tinyint unsigned default 0,
gender enum("男","女","保密") default "保密",
cls_id int unsigned,
birthday date default "2000-09-09"
);
一、增加
1.1 全列插入(插入的数据个数和类型与字段一一对应)
--insert [into] 表名 values(...)
--主键字段 可以用 0 null default 来占位
--向classes表中插入“刺客班”的三种方式 insert into classes values(0, "刺客班");
insert into classes values(null , "刺客班");
insert into classes values(default, "刺客班");
1.2 部分插入
--insert into 表名(列1,...) values(值1,...)
insert into students (name, gender) values("阿狸", 1);
1.3 多行插入,一次插入多个,逗号隔开
insert into students (name, gender) values("赏金", 2),("泰隆", 1);
insert into students values(null, "盲僧", 20, 1, null, default),
(null, "牛头", 20, 1, null, default);
二、修改
--update 表名 set 列1=值1, 列2=值2... where 条件;
update students set gender=2; --更改所有的gender值
update students set gender=1 where name="盲僧"; --更改所有name=”盲僧“的项,不能唯一确认 --update students set gender=1 where id=1, 3, 5, 6, 7, 9; --这样写不行,会报错
update students set gender=1 where id=1; --可以唯一确认
update students set age=30,gender=1 where id=8; --一次修改同个id的多个信息
三、查询(简单查询,下篇详细展开)
3.1 查询所有列
--select * from 表名; * 代表全部
select * from students; --一般数据少的时候可以用,对大量数据不适用
3.2 根据一定条件查询
select * from students where name="盲僧"; --查询所有name=盲僧的信息
select * from students where id<3;
3.3 查询指定列
--select 列1,列2,...from 表名; (如只想查同学的性别)
select name, gender from students; --由此可以理解*代表 所有的列 --可以使用as为列或者表指定别名
--select 字段 as 别名, 字段 as 别名 from 数据表 where ...;
select name as "姓名", gender as "性别" from students; --字段的顺序 由命令中的先后顺序决定
select gender as "性别", name as "姓名", id as "序号" from students;
四、删除
4.1 物理删除(真删,数据来之不易,慎用!)
--delete from 表名 where 条件
delete from students -- 清空数据表,整个students中的数据全部删除
delete from students where name="盲僧";
--此时如果再增加一个信息,id会等于此时的auto_increment值,而不是去补充已删除的值,除非指定
--切记好马不吃回头草,删了就不要再用,否则增长到相同id的时候会崩
4.2 逻辑删除(推荐!)
--思路为:用一个字段表示 这条信息是否已经不能再使用了
--给students添加一个is_delete字段 bit类型
alter table students add is_delete bit default 0;
--比如6号盲僧想在某网站注销信息,这时候网站悄悄假删信息,操作是...
update students set is_delete=1 where id=6;
--查看假装删除的内容(注销的用户)...在is_delete字段会有一个特殊符号
select * from students where is_delete=1;
--此时,以下命令的表格中不会再显示6号盲僧,(假装)删除成功!
select * from students where is_delete=0;
MySQL数据库 | 数据表的增删改查的更多相关文章
- MySQL数据库之表的增删改查
目录 MySQL数据库之表的增删改查 1 引言 2 创建表 3 删除表 4 修改表 5 查看表 6 复制表 MySQL数据库之表的增删改查 1 引言 1.MySQL数据库中,数据库database就是 ...
- Mysql数据库和表的增删改查以及数据备份&恢复
数据库 查看所有数据库 show databases; 使用数据库 use 数据库名; 查看当前使用的数据库 select database(); 创建数据库 create database 数据库名 ...
- MySQL数据库2表的增删改查
目录 一.数据表(文件): 1.1增 1.2查看表内数据 1.3改 1.4删除列表 1.5查看库内列表及表结构 1.6复制表结构 二.列类型:(*********) 2.1数字 2.2字符串 2.3时 ...
- Mysql数据库二:表的增删改查
----建表CREATE TABLE emp( id int PRIMARY key auto_increment, name char(10) , birthday DATE , salary FL ...
- MySQL数据库与表的增删改查
1.值库管理 1.1 查询所有值库 show databases; 1.2 创建一个值库 create database 值库名称 default character set 编码格式名称; 1.3 ...
- Mysql数据表的增删改查
---恢复内容开始--- Mysql数据表的增删改查 1.创建表 语法:CREATE TABLE 表名(字段1,字段2,字段3.......) CREATE TABLE `users` ( `us ...
- 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理
一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...
- AngularJS中使用$http对MongoLab数据表进行增删改查
本篇体验使用AngularJS中的$http对MongoLab数据表进行增删改查. 主页面: <button ng-click="loadCourse()">Load ...
- C# - VS2019 通过DataGridView实现对Oracle数据表的增删改查
前言 通过VS2019建立WinFrm应用程序,搭建桌面程序后,通过封装数据库操作OracleHelper类和业务逻辑操作OracleSQL类,进而通过DataGridView实现对Oracle数据表 ...
随机推荐
- C#实例之简单聊天室(状态管理)
前言 状态管理是在同一页或不同页的多个请求发生时,维护状态和页信息的过程.因为Web应用程序的通信协议使用了无状态的HTTP协议,所以当客户端请求页面时,ASP.NET服务器端都会重新生 ...
- elasticsearch学习(1)
安装 elasticsearch ,操作elasticsearch的工具kibana, (1)在kibana中输入GET _cluster/health查看es的健康状况(2)在kibana中输入 G ...
- 1、微服务--为什么有consul,consul注册,心跳检测,服务发现
一.为什么有consul? 在微服务,每1个服务都是集群式的,订单服务在10台服务器上都有,那么用户的请求到达,获取哪台服务器的订单服务呢?如果10台中的有的订单服务挂了怎么办?10台服务器扛不住了, ...
- SpringBoot整合WEB开发--(九)整合Servlet,Filter,Listener
简介: 如果需要整合第三方框架时,可能还是不得不使用Servlet,Filter,Listener,Springboot中也有提供支持. @WebServlet("/my") pu ...
- jQuery---京东轮播图
京东轮播图 有个计数的,点右边,计数增加,判断计数是否超过总的长度,超过设置计数为0,再设置当前的图片动画,兄弟的图片动画 左边点击同理,计数是--,判断计数是否等于-1,等于则reset计数为总长度 ...
- mac屏幕录制
屏幕录制 shift+command+5 录制完成后将文件拖拽到要保存的文件中
- 优化公式排版和Beamer相关知识
做优化的同学可能会碰到排列形如 max ******* s.t. ***** = * ***** > *** ... 的格式 既要要求 max 和 s ...
- [SDOI2012] Longge的问题 - 欧拉函数
求 \(\sum\limits_{i=1}^{n}gcd(i,n)\) Solution 化简为 \(\sum\limits_{i|n}^{n}φ(\dfrac{n}{i})i\) 筛出欧拉函数暴力求 ...
- nvm —— Node版本管理工具
nvm下载 下载地址 下载nvm-setup.zip文件 nvm安装 1.以管理员身份运行install.cmd文件,设置文件路径 root: C:\Users\Administrator\AppDa ...
- Oracle监听出现的问题总结,以及解决办法
包括的错误类型: 1.ORA-12541: TNS: 无监听程序 2. ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务 3.ORA-12560: TNS: 协议适配器错误 ...