读《SQL经典实例》学数据库(系列一)

目录

  • 友情提醒
  • 第一章、数据库简述
    • 1.1)数据库简述
    • 1.2)常见的数据库软件
    • 1.3)MySQL数据库安装
  • 第二章、SQL语句分类
    • 2.1)操作数据仓库/数据表:DDL
      • 2.1.1)创建数据仓库/数据表
      • 2.1.2)删除数据仓库/数据表
      • 2.1.3)修改数据仓库/数据表
      • 2.1.4)查看数据仓库/数据表
    • 2.2)操作数据表中数据:DML
      • 2.2.1)增加数据(Insert)
      • 2.2.2)删除数据(Delete)
      • 2.2.3)修改数据(Update)
    • 2.3)查询数据表中数据DQL
      • 2.3.1)查询数据(Select)
    • 2.4)控制访问权限:DCL
      • 2.4.1)Grant授予权限
      • 2.4.2)REVOKE 撤销权限
    • 2.5)TCL(Transaction Control )
      • 2.5.1) BEGIN开始新的事务
      • 2.5.2)COMMIT提交当前事务
      • 2.5.3)ROLLBACK回滚事务
      • 2.5.4)SAVEPOINT创建保存点
      • 2.5.5) SET autocommit设置自动提交模式

友情提醒

先看文章目录,大致了解知识点结构,直接点击文章目录可以跳转到文章指定位置。

第一章、数据库简述

1.1)数据库简述

①数据库是什么:水库存水,数据库用来存各种各样的数据。使用数据库主要是为了方便使用SQL语句存储操作数据。
②数据库语言:用于访问和处理数据库的计算机语言。 它大部分是通用的,可适用几乎所有的数据库软件。每一个SQL语句都会有一个执行的结果。SQL语句不区分大小写,以;号结尾。

1.2)常见的数据库软件

①Oracle:收费很贵,适合中大型项目。
②MySql:免费!!!适合中小型项目,所以我们一般学习都用这个,毕竟SQL语言一通百通。
③DB2:收费,适合中大型项目。
④SqlServer:收费,适合中小项目。

1.3)MySQL数据库安装

安装篇幅比较长,看这篇就好点击这里跳转:MySQL数据库安装

第二章、SQL语句分类

2.1)操作数据仓库/数据表:DDL

DDL(Data Definition)数据定义语言,定义数据库结构,包括定义表、视图和索引。操作数据仓库和数据表本身。
语句关键词:

就是操作数据仓库和表
Create
Drop
Alter
Truncate

2.1.1)创建数据仓库/数据表

①创建数据仓库

-- 创建数据仓库,默认编码表为utf-8
-- 格式: create database 数据仓库名称。
create database db_name1;-- 创建数据仓库,创建的同时设置编码表
-- 格式: create database 数据仓库名称 character set 编码表名。
create database db_name2 character set gbk ;

②创建数据表

-- 创建数据表,同时设置字段,数据类型和约束
-- 格式
/* create table 数据表名称(字段1 类型(长度) [约束],字段2 类型(长度) [约束],....字段n 类型(长度) [约束] 
); */
use db_name1;
create table tableName1(sid int primary key auto_increment,# 主键约束 自增长sname varchar(10) comment '解释说明', # 会被编译的注释sex char(1) unique not null,# 唯一约束 非空约束age int unique default 8,# 唯一约束,默认值 8score double not null, # --,#是单行注释,/**/是多行注释birthday date
);

2.1.2)删除数据仓库/数据表

①删除数据仓库

-- 删除单个数据仓库
-- 格式 drop database 数据仓库名称;
drop database db_name1;

②删除数据表

-- 格式:drop table 数据表名称;
drop table tableName;

2.1.3)修改数据仓库/数据表

①修改数据仓库

-- 修改数据仓库编码表,注意写UTF-8的时候不要加-
-- 格式 alter database 数据仓库名称 character set 编码表名;
ALTER database db_name2 CHARACTER set UTF8;-- 切换数据仓库
-- 格式 use 数据仓库名称;
use db_name1;

②修改数据表

-- 增加列
-- 格式:alter table 表名 add 字段 类型(长度) 约束; 
ALTER table tablename1 add newid int not NULL;-- 修改现有列类型、长度和约束语法
-- 格式alter table 表名 modify 字段 类型(长度) 约束;
ALTER TABLE tablename1 MODIFY newid char(4) unique;-- 修改现有列名称语法
-- alter table 表名 change 旧字段名 新字段名 类型(长度) 约束;
ALTER TABLE tablename1 CHANGE newid newname char(4) not null;-- 删除现有列语法
-- alter table 表名 drop 字段;
ALTER TABLE tablename1 DROP newname;-- 修改表的字符集语法 
-- alter table 表名 character set utf8;
ALTER TABLE tablename1 CHARACTER set gbk;-- 修改表名语法
-- rename table 旧表名 to 新表名; 
RENAME TABLE tablename1 to tablename;

2.1.4)查看数据仓库/数据表

①查看数据仓库

-- 查看所有数据仓库
-- 格式:show databases;
show databases;-- 查看数据仓库编码格式
-- 格式: show create database 数据仓库名称。
show create database databaseName;-- 查看目前正在使用的数据仓库
-- 格式: SELECT DATABASE();
SELECT DATABASE();

②查看数据表

-- 查看数据表编码格式
--格式: show create table 数据表名称。
show create TABLE tableName1;-- 查看数据表
show TABLES;-- 查看数据表结构
desc tableName;

2.2)操作数据表中数据:DML

DML(Data Manipulation)数据处理语言,包括插入、删除和修改操作。
语句关键词:

就是增删改数据
Delete
Insert
Update

2.2.1)增加数据(Insert)

-- 添加数据第一种格式 当某列值可以为null,自增长或有默认值时可以省略
-- 格式:insert into 数据表名称 (字段1,字段2,...字段N) values (值1,值2,...值N);
insert into tablename(sid,sname,sex,age,score,birthday)values(3,'张一','男',23,89,'1204');
insert into tablename(sid,sname,sex,age,score,birthday)values(4,'张二','女',26,99,'1205');-- 添加数据第二种格式
-- 格式:insert into 数据表名称 set 字段1=值1,字段2=值2,...字段N=值N;
insert into tablename set sid=5,sname='张三',sex='难',age=20,score=91,birthday='1209';
insert into tablename set sid=6,sname='张四',sex='♀',age=10,score=19,birthday='1200';

举例:

insert into b_pro_evaluate(pid,star,eval)values(1,3,'很好回收率很高');
insert into b_pro_evaluate(pid,star,eval)values(1,2,'非常不错的产品');
insert into b_pro_evaluate(pid,star,eval)values(2,5,'五星好评');

2.2.2)删除数据(Delete)

-- 按照行逐行删除整个表的数据但是表本身还存在
-- 格式: delete from 数据表名称;
delete from tableName;-- 先删表,再建新表 效率高
truncate table student1;-- 按条件删除表中数据
-- 格式:delete from 数据表名称 where 条件语句;
delete FROM tableName where sid=1;

删除表中的数据时没有加where 条件,会删除表中的所有数据,它与truncate 有什么区别?
delete删除表中的数据是按照行逐行删除。 效率低
truncate它是先把表删掉,然后再把表创建出来。 效率高

2.2.3)修改数据(Update)

-- 更新修改数据
-- 格式:update 数据表名称 set 字段1=新值,字段2=新值 where 条件语句; update tableName set age = 15;
update tableName set age = age + 10 where sid % 2 = 0;
update tableName set sname = "小冯",age = 22 where sid = 4;

2.3)查询数据表中数据DQL

(Data Query )数据查询语言,用于查询数据表中的数据,通过select关键字。
语句关键词:

就是查询数据
Select

2.3.1)查询数据(Select)

-- 查询整张表
-- 格式:select * from 数据表名称;
select * from tableName;-- 按条件查询
-- 格式:select * from 数据表名称 where 查询条件;
select * from tableName where sid =4;-- 按条件查询
-- 格式:select 字段1,字段2 ... from 数据表名称 where 查询条件;
select sname,age from tableName where sid =4;

2.4)控制访问权限:DCL

DCL(Data Control)数据控制语言,包括对数据的安全性控制、完整性规则的描述以及对事务的定义、并发控制和恢复。
语句关键词:

Grant
Revoke

2.4.1)Grant授予权限

①授予用户权限
username:要授予权限的用户名。
host:用户连接数据库的主机名(例如,localhost 或 % 表示任何主机)。
password:用户的密码。

--授予用户对所有数据库的所有权限
GRANT ALL PRIVILEGES ON *.* TO 'username'@'host' IDENTIFIED BY 'password';
--授予用户对特定数据库的所有权限
GRANT ALL PRIVILEGES ON database_name.* TO 'username'@'host';
--授予用户对特定表的特定权限
GRANT SELECT, INSERT, UPDATE ON database_name.table_name TO 'username'@'host';
--授予用户创建数据库的权限
GRANT CREATE ON *.* TO 'username'@'host';
--授予用户执行存储过程和函数的权限
GRANT EXECUTE ON PROCEDURE database_name.procedure_name TO 'username'@'host';
GRANT EXECUTE ON FUNCTION database_name.function_name TO 'username'@'host';

2.4.2)REVOKE 撤销权限

撤销权限

--撤销用户对所有数据库的所有权限
REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'username'@'host';
--撤销用户对特定数据库的所有权限
REVOKE ALL PRIVILEGES ON database_name.* FROM 'username'@'host';
--撤销用户对特定表的特定权限
REVOKE SELECT, INSERT, UPDATE ON database_name.table_name FROM 'username'@'host';
--撤销用户创建数据库的权限
REVOKE CREATE ON *.* FROM 'username'@'host';
--撤销用户执行存储过程和函数的权限
REVOKE EXECUTE ON PROCEDURE database_name.procedure_name FROM 'username'@'host';
REVOKE EXECUTE ON FUNCTION database_name.function_name FROM 'username'@'host';

属性权限

--在授予或撤销权限后,最好刷新权限,以确保更改立即生效:
FLUSH PRIVILEGES;

2.5)TCL(Transaction Control )

事务控制语言,用于控制事务。
语句关键词:

BEGIN
Set transaction
Rollback
Savepoint
Commit

2.5.1) BEGIN开始新的事务

BEGIN或 START TRANSACTION开始新的事务

START TRANSACTION;BEGIN;

2.5.2)COMMIT提交当前事务

COMMIT 用于提交当前事务,使事务中的所有更改永久生效。

START TRANSACTION;UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2;COMMIT;

2.5.3)ROLLBACK回滚事务

ROLLBACK用于回滚当前事务,撤销事务中的所有更改。如果事务中的任何操作失败,或者决定不保存更改,可以使用 ROLLBACK 撤销所有更改。这里使用了 ROLLBACK 而不是 COMMIT,意味着事务中的所有更改都不会被保存到数据库中。

START TRANSACTION;UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2;ROLLBACK;

2.5.4)SAVEPOINT创建保存点

SAVEPOINT用于在事务中创建一个保存点,允许回滚到该保存点而不是整个事务。

START TRANSACTION;UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;
SAVEPOINT savepoint1;UPDATE accounts SET balance = balance + 100 WHERE user_id = 2;-- 如果第二个更新失败,可以回滚到保存点
ROLLBACK TO savepoint1;COMMIT;

2.5.5) SET autocommit设置自动提交模式

SET autocommit用于设置自动提交模式。默认情况下,MySQL 是自动提交的,即每个语句都会自动提交。

关闭自动提交:SET autocommit = 0; 关闭自动提交后,需要手动使用 COMMIT 或 ROLLBACK 来结束事务。
重新开启自动提交:SET autocommit = 1;

SET autocommit = 0;UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2;COMMIT;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/893375.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C++】模板(进阶)

本篇我们来介绍更多关于C模板的知识。模板初阶移步至:【C】模板(初阶) 1.非类型模板参数 1.1 非类型模板参数介绍 模板参数可以是类型形参,也可以是非类型形参。类型形参就是我们目前接触到的一些模板参数。 //类型模板参数 …

一文学会YOLO系列算法(从V3到11)实现遥感图像目标检测

目录 前言 数据集介绍 数据集转换 YOLO代码的下载 YOLO的配置 1.数据集的配置 2.模型的配置 YOLO11模型的训练 其它版本YOLO的训练 前言 遥感技术的快速发展,特别是在高分辨率遥感图像的获取能力上的显著提升,已经大大拓宽了遥感数据在环境监测…

图解Git——分布式Git《Pro Git》

分布式工作流程 Centralized Workflow(集中式工作流) 所有开发者都与同一个中央仓库同步代码,每个人通过拉取、提交来合作。如果两个开发者同时修改了相同的文件,后一个开发者必须在推送之前合并其他人的更改。 Integration-Mana…

【高阶数据结构】布隆过滤器(BloomFilter)

1. 概念 1.1 背景引入 背景:在计算机软件中,一个常见的需求就是 在一个集合中查找一个元素是否存在 ,比如:1. Word 等打字软件需要判断用户键入的单词是否在字典中存在 2. 浏览器等网络爬虫程序需要保存一个列表来记录已经遍历过…

【json_object】mysql中json_object函数过长,显示不全

问题:json只显示部分 解决: SET GLOBAL group_concat_max_len 1000000; -- 设置为1MB,根据需要调整如果当前在navicat上修改,只有效本次连接和后续会话,重新连接还是会恢复默认值1024 在my.ini配置文件中新增或者修…

计算机网络 (52)秘钥分配

一、重要性 在计算机网络中,密钥分配是密钥管理中的一个核心问题。由于密码算法通常是公开的,因此网络的安全性主要依赖于密钥的安全保护。密钥分配的目的是确保密钥在传输过程中不被窃取或篡改,同时确保只有合法的用户才能获得密钥。 二、方…

第35天:安全开发-JavaEE应用原生反序列化重写方法链条分析触发类类加载

时间轴: 序列化与反序列化图解: 演示案例: Java-原生使用-序列化&反序列化 Java-安全问题-重写方法&触发方法 Java-安全问题-可控其他类重写方法 Java-原生使用-序列化&反序列化 1.为什么进行序列化和反序列化&#xff1…

MindAgent:基于大型语言模型的多智能体协作基础设施

2023-09-18 ,加州大学洛杉矶分校(UCLA)、微软研究院、斯坦福大学等机构共同创建的新型基础设施,目的在评估大型语言模型在游戏互动中的规划和协调能力。MindAgent通过CuisineWorld这一新的游戏场景和相关基准,调度多智…

Excel 技巧17 - 如何计算倒计时,并添加该倒计时的数据条(★)

本文讲如何计算倒计时,并添加该倒计时的数据条。 1,如何计算倒计时 这里也要用公式 D3 - TODAY() 显示为下面这个样子的 然后右键该单元格,选 设置单元格格式 然后点 常规 这样就能显示出还书倒计时的日数了。 下拉适用到其他单元格。 2&a…

rocketmq基本架构

简介 Name server 负责broker注册、心跳,路由等功能,类似Kafka的ZKname server节点之间不互相通信,broker需要和所有name server进行通信。扩容name server需要重启broker,不然broker不会和name server建立连接producer和consum…

国产编辑器EverEdit - 大纲视图

1 大纲视图 1.1 应用场景 在编辑较长代码文件时,使用大纲视图可以方便的检视当前文件的变量、函数等信息,方便在不同函数间跳转,对整个文档的全貌了然于胸。   在编辑XML文档时,通过展示XML文件的层次结构、节点布局&#xff0…

Linux中的基本指令(一)

一、Linux中指令的存在意义 Linux中,通过输入指令来让操作系统执行,以此达到控制操作系统的目的,类似于Windows中的双击,右键新建文件,新建文件夹等 1.补:关于屏幕的几个操作指令 ①清屏指令 clear 回…

2025/1/21 学习Vue的第四天

睡觉。 --------------------------------------------------------------------------------------------------------------------------------- 11.Object.defineProperty 1.在我们之前学习JS的时候&#xff0c;普通得定义一个对象与属性。 <!DOCTYPE html> <h…

Go Map 源码分析(一)

Go语言中的map是通过哈希表实现的&#xff0c;其底层结构和实现机制如下&#xff1a; 一、hash 结构 hmap结构体&#xff1a;是map的头部结构&#xff0c;主要字段及含义如下&#xff1a; count&#xff1a;表示当前哈希表中的元素数量&#xff0c;与len()函数相对应。flags…

Linux-C/C++--深入探究文件 I/O (上)(文件的管理、函数返回错误、exit()、_Exit()、_exit())

经过上一章内容的学习&#xff0c;相信各位读者对 Linux 系统应用编程中的基础文件 I/O 操作有了一定的认识和理解了&#xff0c;能够独立完成一些简单地文件 I/O 编程问题&#xff0c;如果你的工作中仅仅只是涉及到一些简单文件读写操作相关的问题&#xff0c;其实上一章的知识…

【机器学习实战中阶】音乐流派分类-自动化分类不同音乐风格

音乐流派分类 – 自动化分类不同音乐风格 在本教程中,我们将开发一个深度学习项目,用于自动化地从音频文件中分类不同的音乐流派。我们将使用音频文件的频率域和时间域低级特征来分类这些音频文件。 对于这个项目,我们需要一个具有相似大小和相似频率范围的音频曲目数据集…

Walrus Learn to Earn计划正式启动!探索去中心化存储的无限可能

本期 Learn to Earn 活动将带领开发者和区块链爱好者深入探索 Walrus 的技术核心与实际应用&#xff0c;解锁分布式存储的无限可能。参与者不仅能提升技能&#xff0c;还能通过完成任务赢取丰厚奖励&#xff01;&#x1f30a; 什么是 Walrus&#xff1f; 数据主权如今正成为越…

git 常用命令 git archive

git archive 是 Git 中用于创建一个包含指定提交或分支中所有文件的归档文件&#xff08;如 .tar 或 .zip&#xff09;的命令。这个命令非常适合用于分发项目快照、备份代码库或导出特定版本的文件。 git archive --formatzip --outputproject.zip HEAD …

Excel 技巧15 - 在Excel中抠图头像,换背景色(★★)

本文讲了如何在Excel中抠图头像&#xff0c;换背景色。 1&#xff0c;如何在Excel中抠图头像&#xff0c;换背景色 大家都知道在PS中可以很容易抠图头像&#xff0c;换背景色&#xff0c;其实Excel中也可以抠简单的图&#xff0c;换背景色。 ※所用头像图片为百度搜索&#x…

持续升级《在线写python》小程序的功能,文章页增加一键复制功能,并自动去掉html标签

增加复制按钮后的界面是这样的 代码如下&#xff1a; <template><view><x-header></x-header><view class"" v-if"article_info"><view class"kuai bgf"><view class"ac fs26"><img sr…