数据库之 MySQL --- 数据处理 之 表操作、CRUD(六)
个人博客网:https://wushaopei.github.io/ (你想要这里多有)
一、 表操作
创建数据库
CREATE DATABASE demo
-- 删除数据库
DROP DATABASE demo
-- 创建表
-- 第一种方式 : 白手起家
CREATE TABLE em(
e_id INT PRIMARY KEY, -- primary key 主键,不可重复不能为null
e_name VARCHAR(20),
e_age INT
)
-- 第二种方式: 基于现有的表来创建新的表
DROP TABLE em;CREATE TABLE em2
AS
SELECT first_name
FROM employees
-- 复制employees 表
-- 注意: 表的约束是复制不了的
CREATE TABLE em3
AS
SELECT *
FROM employees
-- 复制employees表但不要里面的内容
CREATE TABLE em4
AS
SELECT *
FROM employees
WHERE 1 = 2;
【1】 修改表
CREATE TABLE em(
e_id INT PRIMARY KEY,
e_name VARCHAR(20),
e_age INT
)
【2】修改列的类型
如果列中没有数据,那么列的类型可以进行修改
如果列中有数据,orcal是不允许修改的。mysql允许但大家需要谨慎修改
ALTER TABLE em
MODIFY e_age VARCHAR(20)
【3】修改列的名称
ALTER TABLE em
CHANGE e_age e_address VARCHAR(20)
【4】添加列
ALTER TABLE em
ADD e_age INT
【5】删除列
ALTER TABLE em
DROP COLUMN e_age
【6】修改表名
-- orcal中 修改表名 alter table em3 rename 旧的名字 to 新的名字
ALTER TABLE em3
RENAME TO emm
DESC em;
【7】删除表
DROP TABLE emm
-- 清空表 - 清空表中的内容,表结构还在
TRUNCATE TABLE em2 -- 不能回滚数据
DELETE FROM em2 -- 可以回滚数据
-- truncate 比 delete from 效率要高
COMMIT; -- 提交,一旦commit就不可以回滚了
SET autocommit = FALSE; -- 设置不允许自动commit
-- delete from em2;
TRUNCATE TABLE em2;
ROLLBACK -- 回滚到上一次的commit
二、事务
例 : AA给BB转钱,转一百块钱
第一个动作 : AA = AA - 100
----- 抛异常了 ------
第二个动作 : BB = BB + 100
思考?如何做到二次动作要完成都完成,要失败都失败
try{
commit;
SET autocommit = FALSE;
第一次动作: AA = AA - 100
System.out.println(1 / 0);
第二次动作: BB = BB + 100
commit;
}catch(Exception e){
rollback;
}
SELECT * FROM em2
CREATE TABLE emp(
emp_id INT PRIMARY KEY, -- 不能重复,不能为null
emp_name VARCHAR (20),
emp_age INT
)
DESC emp
三 、数据操纵语言 -- CRUD

【1】添加数据
-- 第一种
INSERT INTO emp(emp_id,emp_name,emp_age) VALUES(1,'强哥',56)
INSERT INTO emp(emp_id,emp_age) VALUES(2,30)
-- 注意: 没有插入字段的值默认为null
INSERT INTO emp VALUES(4,'成哥',65)
-- 第二种 基于现有的数据
-- 注意列的类型和长度问题
INSERT INTO emp(emp_id,emp_name)
SELECT employee_id,first_name FROM employees
【2】 改
UPDATE emp SET emp_age =20 WHERE emp_id =1
UPDATE emp SET emp_age = 30 -- 修改所有数据的emp_age
【3】 删
DELETE FROM emp WHERE emp_id =1
DELETE FROM emp WHERE emp_id>100
【4】删除失败和修改失败(有外键约束的表中)。
SELECT * FROM departments
DELETE FROM departments WHERE department_id = 50
SELECT * FROM emp
数据库之 MySQL --- 数据处理 之 表操作、CRUD(六)的更多相关文章
- python爬取信息到数据库与mysql简单的表操作
python 爬取豆瓣top250并导入到mysql数据库中 import pymysql import requests import re url='https://movie.douban.co ...
- 数据库之 MySQL --- 数据处理 之 表的约束与分页(七)
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 1.约束 :为了保证数据的一致性和完整性,SQL规范以约束的方式对表数据进行额外的条件限制 ...
- mysql数据库学习(二)--表操作
一.表操作 以下内容都是自己学习的时候看过的一些知识,作为笔记记录一下吧,大部分都是所看文章的内容. 1.创建表 前面的基础篇笔记是相当于搭建了一个方便管理的文件夹树根,下面要学习的是一些关于表的知识 ...
- 百万年薪python之路 -- MySQL数据库之 MySQL行(记录)的操作(二) -- 多表查询
MySQL行(记录)的操作(二) -- 多表查询 数据的准备 #建表 create table department( id int, name varchar(20) ); create table ...
- MySQL之多表操作
前言:之前已经针对数据库的单表查询进行了详细的介绍:MySQL之增删改查,然而实际开发中业务逻辑较为复杂,需要对多张表进行操作,现在对多表操作进行介绍. 前提:为方便后面的操作,我们首先创建一个数据库 ...
- mysql 库与表操作
1. 库操作 1.1. 创建数据库 语法规则:create database 库名; CREATE DATABASE dt55; 在创建库时,希望指定编码语法:create database 库名 c ...
- Oracle 数据库基本操作——实用手册、表操作、事务操作、序列
目录: 0. 参考链接与参考手册1. oracle 实用(常用操作)指令2. 数据库基本操作语法 a) 表操作 1)创建表 2)更新表 3)删除表 4)查询 b) 事务操作 c) 序列操作 1)创建序 ...
- Mysql之数据表操作
数据表操作: 查看当前数据库中所有的表: show tables; 查看当前使用数据库: select database(); 使用数据表: use 表名; 创建数据表: create table 数 ...
- 学习MySQL之单表操作(二)
##单表操作 ##创建表 CREATE TABLE t_employee( empno ), ename ), job ), MGR ), Hiredate DATE DEFAULT '0000-00 ...
随机推荐
- mongodb cluster
假设三台机器,ip分别为192.168.1.10,192.168.1.11,192.168.1.12,分别在每台电脑上下载并解压mongodb,关闭防火墙或者开放防火墙端口 一.安装shard 配置文 ...
- 手把手教你撸一套Redux(Redux源码解读)
Redux 版本:3.7.2 Redux 是 JavaScript 状态容器,提供可预测化的状态管理. 说白了Redux就是一个数据存储工具,所以数据基础模型有get方法,set方法以及数据改变后通知 ...
- 第一行Kotlin系列(三)Intent 向上一页返回数据onActivityResult的使用
1.MainActivity.kt跳转处理 声明全局的按钮对象 private lateinit var button8: Button 实例化按钮对象 button8 = findViewById( ...
- qt creator源码全方面分析(4-6)
目录 Qt插件基础 Qt插件基础 我们知道Qt Creator源码是基于插件架构的,那么我们先来介绍下插件基础知识. 相关内容如下: How to Create Qt Plugins [ - Defi ...
- 👋嗨,你有一份微信好友报告待查收~
全部代码都已上传至我的KLab-
- git 常用 指令累积
1.查询指定文件的修改所有修改日志git log --pretty=oneline 文件名 1. git log filename 可以看到fileName相关的commit记录2. git log ...
- Apache Hudi典型应用场景知多少?
1.近实时摄取 将数据从外部源如事件日志.数据库提取到Hadoop数据湖 中是一个很常见的问题.在大多数Hadoop部署中,一般使用混合提取工具并以零散的方式解决该问题,尽管这些数据对组织是非常有价值 ...
- 「雕爷学编程」Arduino动手做(19)—震动报警模块
37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里 ...
- 查找算法----二分查找与hash查找
二分查找 有序列表对于我们的实现搜索是很有用的.在顺序查找中,当我们与第一个元素进行比较时,如果第一个元素不是我们要查找的,则最多还有 n-1 个元素需要进行比较. 二分查找则是从中间元素开始,而不是 ...
- NPOI导入excel为datatable (xls xlsx xlsm)
使用NPOI导入导出Excel(xls/xlsx)数据到DataTable中 http://www.cnblogs.com/songrun/p/3547738.html NPOI 2.0教程 – 自动 ...