MySQL实战学习之入门基础,夯实你的底层知识,构筑上层建筑(1)

在关系数据库中,数据库表是一系列二维数组的集合,用来存储数据和操作数据的逻辑结构。它由纵向的列和横向的行组成,行被称为记录,是组织数据的单位;列被称为字段,每一列表示记录的一个属性,都有相应的描述信息,如数据类型、数据宽度等。

例如一个有关作者信息的名为authors的表中,每个列包含所有作者的某个特定类型的信息,比如“姓名”,而每行则包含了某个特定作者的所有信息:编号、姓名、性别、专业。

数据类型

数据类型决定了数据在计算机中的存储格式,代表不同的信息类型。常用的数据类型有:整数数据类型、浮点数数据类型、精确小数类型、二进制数据类型、日期/时间数据类型、字符串数据类型。

表中的每一个字段,就是某种指定数据类型,比如上图中“编号”字段为整数数据,“性别”字段为字符型数据。

主键

主键(Primary Key)又称主码,用于唯一地标识表中的每一条记录。可以定义表中的一列或多列为主键,主键列上不能有两行相同的值,也不能为空值。假如,定义authors表,该表给每一个作者分配一个 “作者编号”,该编号作为数据表的主键,如果出现相同的值,将提示错误,系统不能确定查询的究竟是哪一条记录; 如果把作者的“姓名”作为主键,则不能出现重复的名字,这与现实中的情况不相符合,因此“姓名”字段不适合做为主键。

数据库技术构成

=======

数据库系统由硬件部分和软件部分共同构成,硬件主要用于存储数据库中的数据,包括计算机、存储设备等。软件部分则主要包括DBMS、支持DBMS运行的操作系统,以及支持多种语言进行应用开发的访问技术等。

数据库系统

数据库系统有3个主要的组成部分。

  • 数据库:用于存储数据的地方

  • 数据库管理系统:用于管理数据库的软件

  • 数据库应用程序:为了提高数据库系统的处理能力所使用的管理数据库的软件补充

数据库提供了一个存储空间用以存储各种数据,可以将数据库视为-一个存储数据的容器。一个数据库可能包含许多文件,一个数据库系统中通常包含许多数据库。

数据库管理系统(DataBase Management System, DBMS)是用户创建、管理和维护数据库时所使用的软件,位于用户与操作系统之间,对数据库进行统- -管理。 DBMS能定义数据存储结构,提供数据的操作机制,维护数据库的安全性、完整性和可靠性。

虽然已经有了DBMS, 但是在很多情况下,DBMS无法满足对数据管理的要求。数据库应用程序(DataBase Application)的使用可以满足对数据管理的更高要求,还可以使数据管理过程更加直观和友好。数据库应用程序负责与DBMS进行通信、访问和管理DBMS中存储的数据,允许用户插入、修改、删除DB中的数据。

SQL语言

对数据库进行查询和修改操作的语言叫做SQL。SQL的含义是结构化查询语言(StructuredQuery Language)。SQL 有许多不同的类型,有3个主要的标准: ANSI (美国国家标准机构)SQL,对ANSI SQL修改后在1992年采纳的标准,称为SQL -92或SQL2。最近的SQL-99标准,从SQL2扩充而来并增加了对象关系特征和许多其他新功能。其次,各大数据库厂商提供不同版本的SQL,这些版本的SQL不但能包括原始的ANSI标准,而且在很大程度上支持SQL-92标准。

SQL包含以下4个部分。

  • (1)数据定义语言(DDL): DROP、CREATE、ALTER等语句。

  • (2)数据操作语言(DML): INSERT (插入)、UPDATE (修改)、DELETE (删除)语句。

  • (3)数据查询语言(DQL): SELECT 语句。

  • (4)数据控制语言(DCL): GRANT、REVOKE、COMMIT、ROLLBACK等语句。

数据库访问接口

不同的程序设计语言会有各自不同的数据库访问接口,程序语言通过这些接口,执行SQL语句,进行数据库管理。主要的数据库访问接口有:

1. ODBC

Open Database Conectivity (ODBC,开放数据库互连)技术为访问不同的SQL数据库提供了一个共同的接口。ODBC使用SQL作为访问数据的标准。这一接口提供了最大限度的互操作性:一个应用程序可以通过共同的一组代码访问不同的SQL 数据库管理系统(DBMS)。

一个基于ODBC的应用程序对数据库的操作不依赖任何DBMS,不直接与DBMS打交道,所有的数据库操作由对应的DBMS的ODBC驱动程序完成。也就是说,不论是Access、MySQL还是Oracle数据库,均可用ODBC API进行访问。由此可见,ODBC 的最大优点是能以统一的方式处理所有的数据库。

2. JDBC

Java Data Base Connectivity (JDBC, Java 数据库连接)用于Java应用程序连接数据库的标准方法,是- -种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问, 它由一组用Java语言编写的类和接口组成。

3. ADO.NET

ADO.NET是微软在.NET框架下开发设计的- -组用 于和数据源进行交互的面向对象类库。ADO.NET提供了对关系数据、XML和应用程序数据的访问,允许和不同类型的数据源以及数据库进行交互。

4. PDO

PDO (PHP Data Object)为PHP访问数据库定义了一个轻量级的、-致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函 数执行查询和获取数据。PDO是PHP5新加入的一个重大功能。

什么是MySQL

========

MySQL是一个小型关系数据库管理系统,与其他大型数据库管理系统(例如Oracle. DB2、SQL Server等)相比,MySQL 规模小、功能有限,但是它体积小、速度快、成本低,且它提供的功能对稍微复杂的应用来说已经够用,这些特性使得MySQL成为世界上最受欢迎的开放源代码数据库。

MySQL优势

MySQL的主要优势如下:

  • (1)速度:运行速度快。

  • (2)价格:MySQL对多数个人来说是免费的。

  • (3)容易使用:与其他大型数据库的设置和管理相比,其复杂程度较低,易于学习。

  • (4)可移植性:能够工作在众多不同的系统平台上,例如: Windows、 Linux、 Unix、MacOS等。

  • (5)丰富的接口:提供了用于C、C++、Eiffel、 Java、 Perl、 PHP、Python、 Ruby和Tcl

  • 等语言的API。

  • (6)支持查询语言: MySQL可以利用标准SQL语法和支持ODBC (开放式数据库连接)的应用程序。

  • (7)安全性和连接性:十分灵活和安全的权限和密码系统,允许基于主机的验证。连接到服务器时,所有的密码传输均采用加密形式,从而保证了密码安全。并且由于MySQL是网络化的,因此可以在因特网上的任何地方访问,提高数据共享的效率。

MySQL工具

=======

MySQL数据库管理系统提供了许多命令行工具,这些工具可以用来管理MySQL服务器、对数据库进行访问控制、管理MySQL用户以及数据库备份和恢复工具等。而且MySQL提供了图形化的管理工具,这使得对数据库的操作更加简单。

MySQL命令行实用程序

MySQL服务器端实用程序:

  • (1) mysqld: SQL后台程序(即MySQL服务器进程)。该程序必须运行之后,客户端才能通过连接服务器来访问数据库。

  • (2) mysqld_ safe: 服务器启动脚本。在UNIX和NetWare中推荐使用mysqld_ safe来启动mysqld服务器。mysqld_ safe 增加了一些安 全特性,例如当出现错误时重启服务器并向错误日志文件写入运行时间信息。

  • (3) mysql.server: 服务器启动脚本。在UNIX中的MySQL分发版包括mysql.server 脚本。该脚本用于使用包含为特定级别的、运行启动服务的脚本的、运行目录的系统。它调用mysqld_ safe 来启动MySQL服务器。

  • **(4) mysql muli:**服务器启动脚本,可以启动或停止系统上安装的多个服务器。

  • **(5) myisamchk:**用来描述、检查、优化和维护MyISAM表的实用工具。

  • (6) mysqlbug: MySQL 缺陷报告脚本。它可以用来向MySQL邮件系统发送缺陷报告。
    自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

学习分享,共勉

这里是小编拿到的学习资源,其中包括“中高级Java开发面试高频考点题笔记300道.pdf”和“Java核心知识体系笔记.pdf”文件分享,内容丰富,囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点。同时还有Java进阶学习的知识笔记脑图(内含大量学习笔记)!

资料整理不易,读者朋友可以转发分享下!

Java核心知识体系笔记.pdf

记一次蚂蚁金服Java研发岗的面试经历,分享下我的复习笔记面经

中高级Java开发面试高频考点题笔记300道.pdf

记一次蚂蚁金服Java研发岗的面试经历,分享下我的复习笔记面经

架构进阶面试专题及架构学习笔记脑图

记一次蚂蚁金服Java研发岗的面试经历,分享下我的复习笔记面经

Java架构进阶学习视频分享
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
)]

中高级Java开发面试高频考点题笔记300道.pdf

[外链图片转存中…(img-aJmcnRqA-1713506500135)]

架构进阶面试专题及架构学习笔记脑图

[外链图片转存中…(img-pxAiyNc0-1713506500137)]

Java架构进阶学习视频分享
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 10
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值