数据库的相关知识

数据库的相关知识

1.数据库能够做什么?

存储大量数据,方便检索和访问保持数据信息的一致、完整共享和安全通过组合分析,产生新的有用信息

2.数据库作用?

存储数据、检索数据、生成新的数据

3.数据库要求?

统一、安全、性能等

4.概念?

数据库就是"数据"的"仓库"数据库中包含表、关系以及操作对象数据存放在表中

5.操作数据库用户

工具操作:Navicat for MySQL

如何创建用户?

点击用户,点击新建用户,常规输入完,点击保存就可以了。

如何连接新建?

创建用户完之后,点击连接,输入新建的用户名和密码

设置权限:

找到新建,点击编辑用户,点击服务器权限,全部授予,点击SQL预览,复制

点击查询,新建查询,粘贴到上面,把权限改为ALL

重新连接一下就可以了

创建数据库:

1.打开连接,点击数据库,右键点击后新建数据库,把字符集改为

点击确定就新建好了

2.打开新建查询,输入CREATE DATABASE +名称;点击连接刷新

3.使用命令列介面,输入CREATE DATABASE +名称;点击连接刷新

查看数据库:

打开新建查询,输入SHOW DATABASES;

使用命令列介面,点击连接,右键打开

选择数据库:

1.双击点数据库,打开

2.使用命令列介面,输入USE +名称

如何删除数据库?

1.直接右键点击删除数据库

2.使用命令列介面,输入 drop database+名称

刷新连接,显示删除

如何创建

数据完整性就是要求数据库中的数据具有准确性。准确性是通过数据库表的设计和约束来实现的。

种类型的约束保证完整性:

实体完整性:约束方法:唯一约束、主键约束、标识列

域完整性:约束方法:限制数据类型、检查约束、外键约束、默认值、非空约束

引用完整性:约束方法:外键约束

自定义完整性:约束方法:规则、存储过程、触发器

SQL中的运算符
算术运算符:
SELECT 3+2;
SELECT 50-3;
SELECT 32*2;
SELECT 2/10;
SELECT 10%2;
赋值运算符:

=:把一个数或变量或表达式赋值给另一变量

逻辑运算符:

AND:当且仅当两个布尔表达式都为true时,返回TRUE。

OR:当且仅当两个布尔表达式都为false,返回FALSE

NOT:布尔表达式的值取反

比较运算符:
-- 比较运算符
SELECT 3>2;
SELECT 3<5;
SELECT 4>=2;
SELECT 3<=5;
SELECT 3!=4;
SELECT 4<>5;
数值类型

INT:标准整数

VARCHAR[(M)]:可变字符串

CHAR[(M)]:定长字符串

创建表
-- 创建表
-- create table 表名(
-- 字段   类型,
-- 字段   类型,
-- 字段   类型,
-- )

多字段使用逗号分隔

保留字用撇号括起来

单行注释:#...

多行注释:/....../

查看表

运行创建的语法,在所写的数据库表刷新

删除表

语法: DROP TABLE [IF EXISTS] 表名;

修改表名

语法:ALTER TABLE 旧表名 RENAME [TO] 新表名;

添加字段

语法:ALTER TABLE 表名 ADD 字段名 数据类型 [属性];

修改字段

语法:ALTER TABLE 表名 CHANGE 原字段名 新字段名 数据类型 [属性];

删除字段

语法:ALTER TABLE 表名 DROP 字段名

not null 不能为空

数据库约束

ZEROFILL 补零

DEFAULT 默认值

注释:COMMENT

auto_increment 自增

PRIMARY KEY 主键

主键 1.唯一,2.非空 3.int类型可以自增

外键

概念:是另一张表的主键,用来和其他表建立关系用的

作用:保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值或使用空值。

语法

FOREIGN KEY( 子表名) REFERENCES 主表 (主表名)

添加数据

INSERT INTO 表名(字段,字段...) VALUES(值,值...);
字段和值必须一一对应 column count doesn't
有外键时,必须符合条件

主键不能重复

INSERT INTO student(student_no,login_pwd,student_name,
sex,grade_id,phone,address,birthday,email)
VALUES('bq0120','123456','张铮','男',1,'123635343',
'河北','2024-10-14','1234@qq.com');
字段不需要全部都写,必须要写的字段(没有自增的主键,非空的字段,外键)
INSERT INTO student(studen_id,gradet_id)
VALUES('bq0120',9);
不写字段时,必须按顺序添加所有数据
INSERT INTO student
VALUES('bq0020','123456','张三','男',1,'1234566','河北','2024-10-14','1234@qq.com');
有自增主键的表,可以忽略主键,也可以使用默认值
INSERT INTO grade(grade_name) VALUES('鸿蒙1班');
有默认值的字段可以不写内容
有默认值的字段可以代替

多行添加

INSERT INTO subjectes(subject_id,subject_name,subject_hour)
VALUES(null,'as',120),(null,'按时',120),(null,'若凡',120),
(null,'恶妇',120),(null,'合格',120),(null,'方式',120);
主键语法允许修改,但是项目中一般不允许修改主键
UPDATE student SET login_pwd='zhangsan'
 where student_name='张三';
删除
DELETE FROM result where student_result<60;
清空表
TRUNCATE TABLE result 

事务

什么是事务

事务(TRANSACTION)是作为单个逻辑工作单元执行的一系列操作多个操作作为一个整体向系统提交,要么都执行、要么都不执行 事务是一个不可分割的工作逻辑单元

事务必须具备以下四个属性,简称ACID 属性:

原子性:事务是一个完整的操作,事务的各步操作是不可分的(原子的),要么都执行,要么都不执行

一致性:当事务完成时,数据必须处于一致状态

隔离性:并发事务之间彼此隔离、独立,它不应以任何方式依赖于或影响其他事务

持久性:事务完成后,它对数据库的修改被永久保持

如何创建事务

可以在命令行语句里

BEGIN;开始事务(指定事务从此处开始,后续的SQL语句都是一个整体)

UPDATE bank SET morey=morey-500 WHERE name='张三';

UPDATE bank SET morey=morey+500 WHERE name='李四';

COMMIT;提交事务,事务结果

例:如果使用事务解决转账问题

ROLLBACK;回滚事务,数据恢复到原始状态

BEGIN;
UPDATE bank SET morey=morey-500 WHERE name='张三';
DELETE FROM bank WHERE id=1;
UPDATE bank SET morey=morey+500 WHERE name='李四';
ROLLBACK;
自动关闭和开启事务

默认情况下,每条单独的SQL语句视为一个事务关闭默认提交状态后,可手动开启、关闭事务

关闭/开启自动提交状态 SET autocommit = 0|1;

值为0:关闭自动提交

值为1:开启自动提交

# 关闭自动提交
SET autocommit=0;
BEGIN;
UPDATE bank SET morey=morey-500 WHERE name='张三';
DELETE FROM bank WHERE id=1;
UPDATE bank SET morey=morey+500 WHERE name='李四';
ROLLBACK;
-- 打开自动提交
set autocommit=1;

SQL查询

语法

SELECT <列名>

FROM <表名>

WHERE <查询条件表达式>

查询全部的行和列
*代表所有列 ,一般在项目中不允许使用,按需搜索

SELECT * FRO

M Students

where 查询的条件

SELECT student_no,studen_name,sex FROM student3
WHERE sex='男';
列别名

使用AS命名列

SELECT student_no as 学号,studen_name as 姓名,sex as 性别
 FROM student3
WHERE sex='男';
查询null null是从来没有添加过数据,或者添加null
SELECT * from student3 WHERE sex is NULL;
被清空的列 使用''
SELECT * FROM student3 WHERE sex='';
SELECT * FROM student3 WHERE sex='' OR sex IS NULL;
Null 和 ' '的区别

null是空值,表示未被赋值

' '是空字符串,表示非空,只不过值是一个非空字符串而已

分页 (开始,数量)
SELECT * FROM student3 LIMIT 0,5;
SELECT * FROM student3 LIMIT 5,5;

limit 要放在语句的最后

SELECT * FROM student3 WHERE sex='男' LIMIT 0,5;
相关推荐
建投数据44 分钟前
建投数据与腾讯云数据库TDSQL完成产品兼容性互认证
数据库·腾讯云
Hacker_LaoYi2 小时前
【渗透技术总结】SQL手工注入总结
数据库·sql
岁月变迁呀2 小时前
Redis梳理
数据库·redis·缓存
独行soc2 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍06-基于子查询的SQL注入(Subquery-Based SQL Injection)
数据库·sql·安全·web安全·漏洞挖掘·hw
你的微笑,乱了夏天2 小时前
linux centos 7 安装 mongodb7
数据库·mongodb
工业甲酰苯胺3 小时前
分布式系统架构:服务容错
数据库·架构
独行soc4 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘
White_Mountain4 小时前
在Ubuntu中配置mysql,并允许外部访问数据库
数据库·mysql·ubuntu
Code apprenticeship4 小时前
怎么利用Redis实现延时队列?
数据库·redis·缓存
百度智能云技术站4 小时前
广告投放系统成本降低 70%+,基于 Redis 容量型数据库 PegaDB 的方案设计和业务实践
数据库·redis·oracle