【JS逆向基础】数据库之mysql
前言:mysql数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司。MySQL 最流行的关MySQL是一个开源免费的关系型数据库管系型数据库管理系统,在 WEB 应用方面ySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理体积小且开放源代码等优点。系统应用软件之一,具有成本低、速度快
1 安装

命令行中输入Mysql -uroot -p,回车,输入你之前设置的密码,回车,出现Mysql的版本信息即连接成功
1.2 基本操作
;允许连接失败的个数
max connect errors=10;
;服务端使用的字符集默认为utf8mb4
character-set-server=utf8mb4
;创建新表时将使用的默认存储引擎
default-storage-engine-INNODB
;默认使用"mysql native_password"插件认证,mysql native _passworddefault authentication plugin=mysgl native password[mysql]
;设置mysq1网络通信的默认字符集default-character-set=utf8mb4[client]
;设置mysq1客户端连接服务端时默认使用的端口port=3306
;设置mysg1客户端的默认字符集
default-character-set=utf8mb4初始化数据库
重新打开一个cmd黑窗口,输入以下命令,让数据库完成初始化操作。
mysqld --initialize--console
1.3 SQL规范
1,在数据库管理系统中,SQL语句关键字不区分大小写(但建议用大写),参数区分大小写。建议命令大写,数据库名、数据表名、字段名统一小写,如数据库名、数据表名、字段名与关键字同名,使用反引号圈起来,避免冲突。
2,SQL语句可单行或多行书写,默认以英文分号(;)结尾,关键词不能跨多行或简写。
3,字符串跟日期类型的值都要以 单引号括起来,单词之间需要使用半角的空格隔开。
4,用空格和缩进来提高SQL语句的可读性。
SELECT *FROM table_name
WHERE name="moluo";
注释
注释
第一种:
-- 单行注释
第二种:/*
多行注释*/
第三种:
# mysql支持单行注释
常见指令
数据库操作
--1.创建数据库(在磁盘上创建一个对应的文件夹)
create database [if not exists] db name [character set xxx];
--2.查看数据库
show databases;--查看所有数据库
SHOW DATABASESLIKE'$test名';--查看名字中包含 test 的数据库
show create database db name;-- 查看数据库的创建方式
--3.修改数据库
alter database db name[character set xxx]
--4.删除数据库
drop database[if exists]db name;
--5.使用数据库
use db name;--切换数据库 注意:进入到某个数据库后没办法再退回之前状态,但可以通过use进行切换select database();--查看当前使用的数据库
数据表操作
数据表就相当于存储数据的特殊文件,数据表中的一条记录就相当于普通文件的一行内容。
moluo,True,18,2000,广东,计算机科学与技术,python开发
xiaohong,False,17,2001,广西,舞蹈学,音乐老师
与普通文件不同的是,数据表是二维的表格结构

(1)创建数据表
数据表就相当于文件,文件有文件名,自然地,数据表也要有表名。同样道理,数据表中的一条记录就相当于文件的一行内容。只是不同的是,数据表需要定义表头(上图中的首行),称为表的字段名。而且因为数据库的存储数据更加科学、严谨,所以需要创建表时要给每一个字段设置数据类型以及字段约束(完整性约条件)。

1,上面SQL语句中,小括号中的定义字段语句后面必须以英文逗号结尾,而最后一个字段的定义语句不能有英文逗号出现否则报错。2,在同一张数据表中,字段名是不能相同,否则报错!
3,创建数据表的SQL语句中,存储空间和字段约束是选填的,而字段名和数据类型则是必须填写的。
(2)查看数据表
查看所有数据表
列出当前数据库中所有的数据表,语法:
show tables;
查看表结构
以表格形式列出当前数据表的结构信息。语法:
-- 方式1:简单查看
describe 表名;
desc 表名; --desc是describe的缩写
--方式2:详细查看
describe 表名;
desc 表名;
查看建表语句
show createtable 表名 \G;
(3)删除数据表
删除表结构,并把数据一并删除,使用需谨慎,强烈建议先备份后删除,或者直接改表名来代替删除操作。
drop table 表名;
重置表信息
保留数据表结构,但是把数据表存储的数据以及数据表的状态回滚,相当于删除原表,并新建一张一模一样的空数据表。
TRUNCATE table 表名:
表记录操作
【1】添加记录
INSERT 语句有两种语法形式,分别是INSERT...VALUES 语句和 INSERT...SET 语句

【2】查询记录


limit:记录条数限制
SELECT emp limit 1
SELECT* from emp limit 2,5; --跳过前两条显示接下来的五条纪录
SELECT*from emp limit 2,2
distinct:查询去重
SELECT distinct salary from emp order by salary
【3】更新记录
UPDATE<表名>SET字段1-值1,字段2-值2..][WHERE 子句]
【4】删除记录
DELETE FROM表名>[WHERE子][ORDERBY子][LIMIT子]
<表名>:指定要删除数据的表名。
ORDER BY 子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。
WHERE 子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。
LIMIT 子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。
关联表:一对多的表关系
一对多关系为关系数据库中两个表之间的一种关系,该关系中第一个表中的单个行可以与第二个表中的一个或多个行相关,但第二个表中的一个行只可以与第一个表中的一个行相关

CREATE TABLE book
id INT PRIMARY KEY AUTO INCREMENT
title VARCHAR(32)
price DOUBLE(5,2),
Pub id INT NOT NULL
ENGINE-INNODB CHARSETut8:
--出版社表
CREATE TABLE publisher(
id INT PRIMARY KEY AUTO INCREMENT
name VARCHAR(32)
emai1 VARCHAR(32)
addr VARCHAR(32)
)ENGINE=INNODB CHARSETutf8;
--插入数据
INSERT INTo book(title,price,pub id) VALUES
('西游记',15,1),
('三国演义',45,2),
('红楼梦',66,3),
('水浒传',21,2),
('红与黑',67,3),
('乱世佳人',44,6),
('飘',56,1),
('放风筝的人',78,3);-- 子查询
-- 查询水浒传的出版社的名称和邮箱
select pub_id from book where title="水浒传"
select name,email from publisher where id=2
Python操作MySQL
import pymysql
#打开数据库连接
db = pymysql.connect(host='localhost',user='root', passwd='123456',port=3306)
print("连接成功!")
#使用 cursor()方法创建一个游标对象
cursor = db.cursor()
#使用 execute()方法执行 SQL 查询
cursor.execute("SELECT VERSION()")
#使用 fetchone()方法获取单条数据。
data =cursor.fetchone()
print("Database version",data)
#关闭数据库连接
db.close()
Python操作MySQL的类版本
import pymysql
import cryptographyclass Mysql(object):# 类变量-----类空间name = "yuan"# 实例空间def __init__(self):# 打开数据库连接self.db = pymysql.connect(host='localhost', user='root', passwd='12345', port=3306, database="mysql111")print("连接成功!")# 使用 cursor()方法创建一个游标对象self.cursor = self.db.cursor()def foo(self):# 使用 execute()方法执行 SQL 查询self.cursor.execute("SELECT * FROM mysql111.user")# 使用 fetchone()方法获取单条数据。data = self.cursor.fetchall()print("Database version", data)# 关闭数据库连接self.db.close()def fuu(self):print("fuu")m = Mysql()
m.foo()