MYSQL基础问题
一.DBMS 是什么
DBMS(Database Management System),数据库管理系统,是一种操纵和管理 数据库的大型软件,用于建立、使用和维护数据库。对数据库进行统一的管理和 控制,以保证数据库的安全性和完整性。
二、实体和实体之间的关系有哪些,外键上应该如何体现
一对一:外键字段放在使用频率高的表上,比如一个用户对应一个病人信息, 一个病人对应一个用户
一对多:外键字段放在多的一方,比如一个班级对应多个学生
多对多:建在关系表中,比如一个学生可以选择多个课程,一个课程可以被 多个学生选择,学生和课程之间就是多对多
三、 数据库三大范式是怎么样的
第一范式: 每列保证原子性,属性不可分割,每个属性都是不可分割的原子项
第二范式: 首先满足第一范式; 必须要有一个主键; 如果主键是复合主键,除了主键以外的其他列必须完全依赖于主键列, 不能只依赖主键的一部分;
第三范式: 满足第二范式 除了主键以外的其他列必须直接依赖于主键,不能间接依赖于主键
四.什么样的列适合建立主键
-
选择尽量更新少的列作为主键,尽量选择没有业务含义的列作为主键
-
一个表只有一个主键约束,但主键约束可以使组合键,但组合键尽量少用
-
主键不能为 null
五、主键约束和唯一约束有什么区别
1.同一张表可以有多个唯一约束,但只能有一个主键;
2.主键字段不能为 null,但唯一约束可以为 null;
3.主键字段可以作为其他表的外键,但唯一约束字段不可以作为其他表的 外键。
六.TRUNCATE TABLE 和 delete from 有什么区别 1
1.语句格式: Delete From: Delete from 表名(where 条件); Truncate table:truncate table 表名;
2.删除表数据不同 Delete from:可以删除整张表数据或删除指定条件的记录行; Truncate table:只能删除整张表数据,不能删除指定的行;
3.释放空间不同
delete from:删除数据后,不会释放表所占用的内存空间,删除后可撤销,删除操作会做日志记录
Truncate table:删除数据后,会释放表占用的内存空间,删除后不可撤销,删除操作不会记录日志
4.执行速度不同 Delete from:速度慢 Truncate table:速度快
七、sql 语句的分类有哪些
1.DQL(数据查询语言)select
2.DML(数据库操作语言) insert、delete、update
3.DDL(数据库定义语言)创建数据库中的各种对象,创建删除修改表结构
4.DCL(数据控制语句)授予或回收访问数据库的某种特权,并控制数据库 操纵事务发生的时间及效果,对数据库进行实时监视
八、mysql 中,char 和 varchar 有什么区别(看笔记找答案)
1.场景区别:char适合存放定长字符串,varchar存放长度可变的字符串 2.后面的数字:字符个数,char后面最多可以写到255,varchar:一行数据最多占65535个字节(除去Bolb类的数据类型)除去其他列所占的空间,剩余的空间和varchar后面写的字符个数有关系,编码不同,一个字符 所占用的存储空间也不一样,所以也会影响varchar后字符个数3.char是固定长度,char(5),如果存放了3个字符,也会按照5个字符占用存储空间varchar(5):可变长度,如果存储了3个字符,会按照3个字符占用存储空间。 4.速度区别:char优于varchar 5.空格的处理:char会消灭掉字符后自己插入的空格,varchar不会
九.mysql 中,dataTime 和 timestamp 有什么区别
相同点:存储格式相同 datetime 和 timestamp 两者的时间格式都是 YYYY-MMDD HH:MM:SS
不同点:存储范围不同,datetime 的范围是 1000-01-01 到 9999-12-31,而 timestamp 是从 1970-01-01 到 2038-01-19,即后者的时间范围很小。
与时区关系:datetime 是存储服务器当前的时区,而 timestamp 类型,是将服务 器当前时间转换为 UTC(世界时间)来存储,即 datetime 与时区无关,存什么, 返回什么,而 timestamp 存储的时间,返回的时间会随着数据库的时区不同而 发生改变。
九.mysql 中,enum 和 set 有什么区别
enum和set的区别:enum只能从列出来的值中选择一个作为数据,set可以从列出来的值中选择多个值作为数据
十、mysql 中的这些函数,能说出来一些
select if(1>2,2,3)
select ifnull(title,0) from book
#如果两个表达式补相等,返回表达式1,否则返回null
select nullif('abc','abc1')
#将参数进行连接(必然会使用)
select concat('a','*','b')
select concat(title,',',type,',',bookid) from book
#第一个参数为分隔符
select CONCAT_WS('*',title,type,bookid) from book
#字符串截取,索引从1开始(字符串,开始位置,长度)
select substring('abcde',2,2)
#去掉字符串收尾的空格
select trim(' bcde ')
create table test4(t_id int primary key auto_increment,t_name varchar(20)
)
insert into test4(t_name)values("amdin")
#返回最后一次插入的自增列的值(非常实用)
select LAST_INSERT_ID()
select CURDATE()
select CURRENT_DATE()
select CURTIME()
select CURRENT_TIME()
SELECT NOW()
select DATE_ADD(NOW(),INTERVAL -6 MONTH);
select DATE_ADD(CURRENT_DATE,INTERVAL 6 DAY);
select DATE_ADD(CURRENT_DATE,INTERVAL 6 HOUR);
select DATE_ADD(CURRENT_DATE,INTERVAL 6 YEAR);
select DATE_ADD(now(),INTERVAL 6 MINUTE);
select DATE_ADD(now(),INTERVAL 6 SECOND);
select DATE_ADD(CURRENT_DATE,INTERVAL 6 WEEK);
SELECT DATE_SUB(CURRENT_DATE,INTERVAL -6 MONTH);
SELECT MONTH(now()) 获取时间的月份
SELECT year(now()) 获取时间的年份
#y代表两MONTH(NO)位年份 Y代表4位年份 h代表12小时制 H代表24小时制
select DATE_FORMAT(CURRENT_TIMESTAMP(),'%y/%m/%d %h:%i:%s')
select DATE_FORMAT(CURRENT_TIMESTAMP(),'%Y/%m/%d %H:%i:%s')
十一、mysql 中的自然连接是怎么会事情,举个例子说明下 natural join
自然连接 条件:两张连接的表中作为联合条件的列的列名称和类型完全一致
create table bookType(type_id int auto_increment primary key,type_name varchar(20)
)
create table books(book_id int auto_increment primary key,book_name varchar(20),type_id INT,foreign key(type_id) REFERENCES bookType(type_id)
)
select * from bookType
insert into bookType(type_name)values('计算机类'),('文学类')
insert into books(book_name,type_id)values('JAVA基础',1),('JAVA编程思想',1),
('西游记',2),('三国演义',2)
insert into books(book_name,type_id)values('JAVA基础',null)
#自然连接,条件:需要联合条件所涉及的列的列名需要一样
#自然内连接
select * from books NATURAL join bookType
#自然左连接
select * from books NATURAL left join bookType
#自然右连接
select * from books NATURAL right join bookType
#交叉连接
select * from books cross join bookType on books.type_id=bookType.type_id相关文章:
MYSQL基础问题
一.DBMS 是什么 DBMS(Database Management System),数据库管理系统,是一种操纵和管理 数据库的大型软件,用于建立、使用和维护数据库。对数据库进行统一的管理和 控制,以保证数据库的安全性和完整性。 二…...
SpringBoot使用Guava实现日志脱敏(含源码)
点击下载《SpringBoot使用Guava实现日志脱敏(含源码)》 1. 摘要 本文将介绍如何使用Google Guava库进行日志脱敏,保护敏感数据的安全。我们将详细解释脱敏的必要性,然后介绍如何使用Guava中的Strings、Maps和CharMatcher类来进行…...
数据结构—动态查找
动态查找介绍 1. 动态查找的引入:当查找表以线性表的形式组织时,若对查找表进行插入、删除或排序操作,就必须移动大量的记录,当记录数很多时,这种移动的代价很大。 2. 动态查找表的设计思想:表结构本身是…...
Tarjan算法学习笔记
目录 无向图的割点与桥 时间戳: 搜索树: 追溯值: 割边判定法则: 割点判定法则: 无向图的双连通分量 定理: 边双连通分量(e-DCC)的求法: e-DCC的缩点: 有向图的连通性 追…...
vue 项目涉及的焦点聚焦、格式化日期、判断是否为对象或数组、判断是否为空、深拷贝、节流、防抖
焦点聚焦 import Vue from vue // 插件对象(必须有 install 方法, 才可以注入到 Vue.use 中) export default {install () {Vue.directive(fofo, {inserted (el) {el el.querySelector(input)el.focus()}})} }格式化日期格式 export const formatDate (time) > {// 将xx…...
软件工程知识梳理6-运行和维护
软件维护需要的工作量很大,大型软件的维护成本高达开发成本的4倍左右。所以,软件工程的主要目的就是要提高软件的可维护性,减少软件维护所需要的工作量,降低软件系统的总成本。 定义:软件已经交付使用之后,…...
docker- php7.4
安装 gd拓展 anzhuanga在Dockerfile里面安装php7.4的GD库 - 知乎 apt update apt install -y libwebp-dev libjpeg-dev libpng-dev libfreetype6-devdocker-php-source extractdocker-php-ext-configure gd \ --with-jpeg/usr/include \ --with-freetype/usr/include/docker-…...
开发一个Android App,在项目中完成添加联系人的功能,通过ContentResolver向系统中添加联系人信息。
实现步骤: (1)添加动态联系人的权限。 (2)创建Activity和布局文件,添加输入框和按钮等控件。 (3)完成添加联系人的功能。 代码文件如下: activity_main.xml文件 <!…...
Flume搭建
压缩包版本:apache-flume-1.9.0-bin.tar 百度盘链接:https://pan.baidu.com/s/1ZhSiePUye9ax7TW5XbfWdw 提取码:ieks 1.解压 tar -zxvf /opt/software/apache-flume-1.9.0-bin.tar.gz -C /opt/module/ 2. 修改文件名 [rootbigdata1 opt]…...
Web APIs 1 DOM操作
Web APIs 1 引入:const优先Web API 基本认知01 作用和分类02 什么是DOM03 DOM树04 DOM对象 获取DOM对象01 根据CSS选择器获取02 其他获取DOM元素方法 操作元素内容01 innerText 属性02 innerHTML 属性 操作元素属性操作元素的常用属性操作元素的样式属性操作表单元素…...
dvwa,xss反射型lowmedium
xss,反射型,low&&medium low发现xss本地搭建实操 medium作为初学者的我第一次接触比较浅的绕过思路high low 发现xss 本关无过滤 <script>alert(/xss/)</script> //或 <script>confirm(/xss/)</script> //或 <scr…...
从云计算到物联网:虚拟化技术的演变与嵌入式系统的融合
文章目录 一、硬件性能提升:摩尔定律与嵌入式虚拟化二、CPU多核技术:为嵌入式虚拟化提供支持三、业务负载整合:嵌入式虚拟化的核心需求四、降低硬件成本:虚拟化技术的经济效益五、软件重用与移植:虚拟化技术的优势六、…...
linux 文件查看 head 、 cat 、 less 、tail 、grep
查看文件详细信息 stat 文件 cat 》》适合显示小文件【行数比较少】,如果行数较多,屏幕显示不完整(如果虚拟操作,是无法上下键的,或者滚动鼠标的,第三方 xsheel,crt 可以方向键查看…...
13.2 Web与Servlet进阶(❤❤)
13.2 Web与Servlet进阶 1. 请求与响应1.1 URL与URI1.2 HTTP请求的结构1. 结构2.后端获取访问工具类型:getHeader().toLowerCase方法1.3 响应的结构1. 结构2. 响应常见状态码3. 后端设置响应参数4. 响应的ContentType作用1.4 请求转发与响应重定向应用1. 请求转发:getRequestDis…...
记录解决报错--vue前后端分离,接口401(Unauthorized)
1.场景 前端访问不了后端接口。报错401。 2.解决步骤 ①在页面console.log(111)查看走到代码的位置没有。(走到了,没问题) ②查看vue.config.js配置。这段配置就是vue访问api的url。(没问题) devServer: {port: 80…...
【笔记】Android 常用编译模块和输出产物路径
模块&产物路径 具体编译到软件的路径要看编译规则的分区,代码中模块编译输出的产物基本对应。 Android 代码模块 编译产物路径设备adb路径Comment 模块device/mediatek/system/common/ 资源overlay/telephony/frameworks/base/core 文件举例res/res/values-m…...
部署私有知识库项目FastGPT
FastGPT 是一个基于 LLM 大语言模型的知识库问答系统,提供开箱即用的数据处理、模型调用等能力。同时可以通过 Flow 可视化进行工作流编排,从而实现复杂的问答场景。 项目文档: [快速了解 FastGpt | FastGptFastGPT 是一个基于 LLM 大语言模型的知识库问答系统,提供开箱即…...
【2024-02-02】华为秋招笔试三道编程题解
恭喜发现宝藏!搜索公众号【TechGuide】回复公司名,解锁更多新鲜好文和互联网大厂的笔经面经。 作者TechGuide【全网同名】 订阅专栏: 【专享版】2024最新大厂笔试真题解析,错过必后悔的宝藏资源! 第一题:找…...
银行数据仓库体系实践(8)--主数据模型设计
主数据区域中保留了数据仓库的所有基础数据及历史数据,是数据仓库中最重要的数据区域之一,那主数据区域中主要分为近源模型区和整合(主题)模型区。上一节讲到了模型的设计流程如下图所示。那近源模型层的设计在第2.3和3这两个步骤…...
vue在main.js中引入三方插件不生效的原因
有的时候需要比较复杂的功能,但是自己实现比较复杂的话,可以引入第三方插件.如果这个第三方插件需要全局都使用的话,可以在main.js中进行引入. 比如router elementplus之类的. import { createApp } from vue import ElementPlus from element-plus import element-plus/dist/…...
【根据当天日期输出明天的日期(需对闰年做判定)。】2022-5-15
缘由根据当天日期输出明天的日期(需对闰年做判定)。日期类型结构体如下: struct data{ int year; int month; int day;};-编程语言-CSDN问答 struct mdata{ int year; int month; int day; }mdata; int 天数(int year, int month) {switch (month){case 1: case 3:…...
python打卡day49
知识点回顾: 通道注意力模块复习空间注意力模块CBAM的定义 作业:尝试对今天的模型检查参数数目,并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...
大话软工笔记—需求分析概述
需求分析,就是要对需求调研收集到的资料信息逐个地进行拆分、研究,从大量的不确定“需求”中确定出哪些需求最终要转换为确定的“功能需求”。 需求分析的作用非常重要,后续设计的依据主要来自于需求分析的成果,包括: 项目的目的…...
服务器硬防的应用场景都有哪些?
服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式,避免服务器受到各种恶意攻击和网络威胁,那么,服务器硬防通常都会应用在哪些场景当中呢? 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...
Frozen-Flask :将 Flask 应用“冻结”为静态文件
Frozen-Flask 是一个用于将 Flask 应用“冻结”为静态文件的 Python 扩展。它的核心用途是:将一个 Flask Web 应用生成成纯静态 HTML 文件,从而可以部署到静态网站托管服务上,如 GitHub Pages、Netlify 或任何支持静态文件的网站服务器。 &am…...
[10-3]软件I2C读写MPU6050 江协科技学习笔记(16个知识点)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16...
NLP学习路线图(二十三):长短期记忆网络(LSTM)
在自然语言处理(NLP)领域,我们时刻面临着处理序列数据的核心挑战。无论是理解句子的结构、分析文本的情感,还是实现语言的翻译,都需要模型能够捕捉词语之间依时序产生的复杂依赖关系。传统的神经网络结构在处理这种序列依赖时显得力不从心,而循环神经网络(RNN) 曾被视为…...
ios苹果系统,js 滑动屏幕、锚定无效
现象:window.addEventListener监听touch无效,划不动屏幕,但是代码逻辑都有执行到。 scrollIntoView也无效。 原因:这是因为 iOS 的触摸事件处理机制和 touch-action: none 的设置有关。ios有太多得交互动作,从而会影响…...
全志A40i android7.1 调试信息打印串口由uart0改为uart3
一,概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本:2014.07; Kernel版本:Linux-3.10; 二,Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01),并让boo…...
Mac下Android Studio扫描根目录卡死问题记录
环境信息 操作系统: macOS 15.5 (Apple M2芯片)Android Studio版本: Meerkat Feature Drop | 2024.3.2 Patch 1 (Build #AI-243.26053.27.2432.13536105, 2025年5月22日构建) 问题现象 在项目开发过程中,提示一个依赖外部头文件的cpp源文件需要同步,点…...
