个人博客网: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(六)的更多相关文章

  1. python爬取信息到数据库与mysql简单的表操作

    python 爬取豆瓣top250并导入到mysql数据库中 import pymysql import requests import re url='https://movie.douban.co ...

  2. 数据库之 MySQL --- 数据处理 之 表的约束与分页(七)

    个人博客网:https://wushaopei.github.io/    (你想要这里多有)     1.约束 :为了保证数据的一致性和完整性,SQL规范以约束的方式对表数据进行额外的条件限制 ​ ...

  3. mysql数据库学习(二)--表操作

    一.表操作 以下内容都是自己学习的时候看过的一些知识,作为笔记记录一下吧,大部分都是所看文章的内容. 1.创建表 前面的基础篇笔记是相当于搭建了一个方便管理的文件夹树根,下面要学习的是一些关于表的知识 ...

  4. 百万年薪python之路 -- MySQL数据库之 MySQL行(记录)的操作(二) -- 多表查询

    MySQL行(记录)的操作(二) -- 多表查询 数据的准备 #建表 create table department( id int, name varchar(20) ); create table ...

  5. MySQL之多表操作

    前言:之前已经针对数据库的单表查询进行了详细的介绍:MySQL之增删改查,然而实际开发中业务逻辑较为复杂,需要对多张表进行操作,现在对多表操作进行介绍. 前提:为方便后面的操作,我们首先创建一个数据库 ...

  6. mysql 库与表操作

    1. 库操作 1.1. 创建数据库 语法规则:create database 库名; CREATE DATABASE dt55; 在创建库时,希望指定编码语法:create database 库名 c ...

  7. Oracle 数据库基本操作——实用手册、表操作、事务操作、序列

    目录: 0. 参考链接与参考手册1. oracle 实用(常用操作)指令2. 数据库基本操作语法 a) 表操作 1)创建表 2)更新表 3)删除表 4)查询 b) 事务操作 c) 序列操作 1)创建序 ...

  8. Mysql之数据表操作

    数据表操作: 查看当前数据库中所有的表: show tables; 查看当前使用数据库: select database(); 使用数据表: use 表名; 创建数据表: create table 数 ...

  9. 学习MySQL之单表操作(二)

    ##单表操作 ##创建表 CREATE TABLE t_employee( empno ), ename ), job ), MGR ), Hiredate DATE DEFAULT '0000-00 ...

随机推荐

  1. Day_11【集合】扩展案例5_对list集合对象中的元素进行反转,求最大值最小值,求元素i在list集合中首次出现的索引,将oldvalue替换为newvalue

    分析以下需求,并用代码实现 定义MyArrays工具类,该工具类中有以下方法,方法描述如下: 1.public static void reverse(ArrayList<Integer> ...

  2. Openwrt:编译固件提示[mktplinkfw] error: images are too big 错误

    在编译mr3420的固件时,添加了luci.jamvm,但是最终编译的固件"openwrt-ar71xx-generic-tl-mr3420-v1-squashfs-factory.bin& ...

  3. python学习(11)文件的读写操作

    1.读文件的7种操作模式 操作模式 具体含义 'r' 读取 (默认) 'w' 写入(会先截断之前的内容) 'x' 写入,如果文件已经存在会产生异常 'a' 追加,将内容写入到已有文件的末尾 'b' 二 ...

  4. Lottery

    0x01 修改金币到8位,才能买东西 robots.txt中发现.git泄露 下载附件,得到源码 审计api.php 我们传入的值与随机生成的值进行比较, 按照相同的个数,得到不同的钱 if($num ...

  5. 我的linux学习日记day8

    链接文件 linux中链接有两种,一种是硬链接,一种是软链接 一.硬链接 硬链接是指通过索引节点来进行链接创建硬链接的方法如下:ln 源文件 硬链接文件具有相同inode号的多个文件互为硬链接文件删除 ...

  6. 策略模式C++实现

    #include <iostream> using namespace std; class Strategy; class Context { public: Context(Strat ...

  7. Rabbit的字符串 字符串最小表示法

    Rabbit的字符串 #include<bits/stdc++.h> using namespace std; ; char s[maxn]; int get_min_pos() { , ...

  8. Django模板之认证机制(csrf_token)

    csrf认证机制: django中对POST请求,csrf会进行认证处理,csrf认证机制是防御跨站伪造功能,在没有任何处理的前提下,POST请求会报错. csrf认证中间件是在process_vie ...

  9. OGG应用进程abend报错无法insert虚拟列

    环境11.2.0.4 linux6.9 RAC2节点,ogg版本Version 12.2.0.1.160823 OGGCORE_OGGADP.12.2.0.1.0_PLATFORMS_161019.1 ...

  10. mysql小白系列_12 sysbench

    压测 1.查看机器负载load top - load average 1m 5m 15m cat /proc/loadavg 与CPU个数有关,1个load表示1个CPUcat /proc/cpuin ...