MySQL学习笔记之中的一个 MySQL入门

本人之前接触的关系型数据库主要是oracle和sqlserver,而对于mysql知之甚少,但查阅网上资料发现,mysql与oracle非常相似,所以学起来应该不会非常费劲,在总结的时候可能很多其它的把关注点放在它与oracle的不同之处。

一、简单介绍

MySQL是一个真正的多用户、多线程SQL数据库server。SQL(结构化查询语言)是世界上最流行的和标准化的数据库语言。MySQL是一个client/server结构的实现,

它由一个server守护程序mysqld和非常多不同的客户程序和库组成。

MySQL的普及并不局限于开放源码团队内。尽管它在个人计算机上执行(确实,MYSQL的开发一般在不昂贵的linux系统上进行),但它是可移植的,而且能够执行

在商用操作系统和一直到企业server的各种硬件上。此外,它的性能也足以和不论什么其它系统相匹敌,并且它还能够处理具有数百万级的大型数据库。

1.1 MYSQL优势:

1、速度。MySQL 执行速度非常快。开发人员声称MySQL 可能是眼下能得到的最快的数据库。

2、使用简单。MySQL 是一个高性能且相对简单的数据库系统,与一些更大系统的设置和管理相比,其复杂程度较低。

3、价格可免费。MySQL 对多数个人用户来说是免费的。

4、支持查询语言。MySQL 能够利用SQL(结构化查询语言),SQL 是一种全部现代数据库系统都选用的语言。也能够利用支持ODBC(开放式数据库连接)的应用程序,ODBC 是Microsoft 开发的一种数据库通信协议。

5、性能高。很多客户机可同一时候连接到server。多个客户机可同一时候使用多个数据库。可利用几个输入查询并查看结果的界面来交互式地訪问MySQL。

6、连接性和安全性优越。MySQL 是全然网络化的,其数据库可在因特网上的不论什么地方訪问,因此,能够和不论什么地方的不论什么人共享数据库。并且MySQL 还能进行訪问控制,能够控制哪些人不能看到您的数据。

7、可移植性强。。MySQL 可执行在各种版本号的UNIX 以及其它非UNIX 的系统(如Windows 和OS/2)上。

二、 关系型数据库管理系统(RDBMS)

一个关系型表有一组命名的属性(a t t r i b u t e )或列,以及一组元组(t u p l e )或行。有时列被称为域,行被称为记录,列和行的交集通常被叫做单元。列标示位置,有作用域或数据类型,比如字符或整数。行自己就是数据。

关系表必须符合某些特定条件

1、存储在单元中的数据必须是原子的。每一个单元仅仅能存贮一条数据,这也叫信息原则(Information Principle )。虽然在过去的数年中按某些违反这一条的方式已经建立了很多系统,但违反这一条将不能运用良好的设计原则。当一个单元包括多于一条的信息时,这叫做信息编码(information coding )。在这种情况下,是否採用违背理论的方案是一个设计的选择问题,虽然在多数情况下,结果证明这对数据的完整性是一不利的。

2、存储在列下的数据必须具有同样的数据类型

3、每行必须唯一

4、列没有顺序

5、行没有顺序

6、列名称唯一

关系模型两个完整性原则:实体完整性原则简洁地表明主键不能所有或部分地空缺或为空,引用完整性原则简洁地表明一个外键必须为空或者与它所引用的主键当前存在的值相一致。

2.1 SQL与非过程化程序设计语言

    SQL是一种典型的非过程化程序设计语言,这样的语言的特点是:仅仅指定哪些数据被操纵,至于对这些数据要运行哪些操作,以及这些操作是怎样运行的,则未被指定。

与之相相应的是过程化程序设计语言,我们寻常熟悉的各种高级程序设计语言都属于这一范畴。这样的语言的特点是:一条语句的运行是与其前后的语句和控制结构(如条件语句、循环语句等)相关的。

SQL这样的语言被设计为不同意你依照某种特定的顺序来取出记录,由于这样做会减少SQL Sever取记录的效率。使用SQL,你仅仅能按查询条件来读取记录。

三、MYSQL数据处理

MySQL支持大量的列类型,它能够被分为3类:数字类型、日期和时间类型以及字符串(字符)类型。

3.1 字符串值:

在字符串中不仅能够使用普通的字符,也可使用几个转义序列,它们用来表示特殊的字符。每一个转义序列以一个反斜杠(“\”)開始,指出后面的字符使用转义字符来解释,而不是普通字符。注意NUL 字节与NULL 值不同;NUL 为一个零值字节,而NULL 代表没有值。

引號在字符串中使用注意事项:

假设串是用同样的引號括起来的,那么在串中须要引號的地方反复写该引號就可以。

假设串是用另外的引號括起来的,则不须要双写对应引號,直接在串中使用,该引號不被特殊对待。

使用反斜杠,用转移序列的方式表示;这样的方法不去管用来将串括起的是单引號还是双引號。

3.1.1 MySQL字符串列类型

3.2 数字值:

MySQL 支持说明为整数(无小数部分)或浮点数(有小数部分)的值。

MySQL 支持科学表示法。科学表示法由整数或浮点数后跟“e”或“E”、一个符号(“+”或“-”,必须具有)和一个整数指数来表示。

3.2.1 MySQL数字列类型

3.2.2 十六进制数字:

MySQL支持十六进制值。以十六进制形式表示的整数由“0x”后跟一个或多个十六进制数字(”0”到“9”及“a”到“f”)组成。十六进制数字不区分大写和小写,但其前缀“0x”不能为“0X”。即0x0a 和0x0A 都是合法的,但0X0a 和0X0A 不是合法的。

在数字上下文,它们表现类似于一个整数(64位精度)。在字符串上下文,它们表现类似于一个二进制字符串,这里每一对十六进制数字被变换为一个字符。

3.3 日期和时间列类型:

时间: 2024-08-10 17:20:45

MySQL学习笔记之中的一个 MySQL入门的相关文章

MySQL学习笔记之九:MySQL Replication

Mysql内建的复制功能是构建大型.高性能应用程序的基础.复制功能不仅有利于构建高性能的应用,同时也是高可用性.可扩展性.灾难恢复.备份以及数据仓库等工作的基础. 一.复制概述 1.复制的功用 数据分布.负载均衡.备份.高可用性.MySQL升级测试 2.复制的工作原理 ①主库把数据更改记录到二进制日志(binary log)中 ②备库将主库的二进制日志复制到本地的中继日志(relay log)中.首先,备库会启动一个I/O线程,跟主库建立一个普通的客户端连接,然后在主库上启动一个特殊的二进制转储

mysql学习笔记(七)—— MySQL内连接和外连接

    MySQL内连接(inner join on) MySQL的内连接使用inner join on,它的效果跟使用where是一样的,如果联结的是两个表,那么需要左右的条件或者说字段是需要完全匹配的. 来看个例子:有两张表customers客户表和orders订单表,外键是cust_id,我们需要知道哪些客户有订单 select customers.cust_id,orders.order_num from customers , orders where customers.cust_i

mysql学习笔记(二)--- MySQL数据类型

[正文] 上一章节中,我们学习了MySQL软件的安装,既然软件都装好了,现在就正式开始MySQL的基础知识的学习吧,即使是零基础,也要一步一个脚印.恩,首先要学习的就是MySQL的数据类型. 一.数据类型: 1.整型(xxxint) 2.浮点型(float和double) 3.定点数(decimal) 4.字符串(char,varchar,xxxtext) 5.二进制数据(xxxBlob) 6.日期时间类型 二.数据类型介绍: 1.整型: 注:M表示最大的显示宽度.其中,int用的最多. 2.浮

MySQL学习笔记(六)—— MySQL自连接

有的时候我们需要对同一表中的数据进行多次检索,这个时候我们可以使用之前学习过的子查询,先查询出需要的数据,再进行一次检索. 例如:一张products表,有产品id,供应商id(vend_id),产品名称等等. mysql> select * from products; +---------+---------+-----------+------------+-----------+ | prod_id | vend_id | prod_name | prod_price | prod_de

MYSQL学习笔记——数据库范式及MYSQL优化整体思路

一.数据库范式                                                                               为了建立冗余较小.结构合理的数据库,设计数据库时必须遵循一定的规则.在关系型数据库中这种规则就称为范式.范式是符合某一种设计要求的总结.要想设计一个结构合理的关系型数据库,必须满足一定的范式. 1.1.第一范式(1NF:每一列不可包含多个值)      所谓第一范式(1NF)是指数据库表的每一列都是不可分割的基本数据项,同一列

jquery-mobile 学习笔记之中的一个(基础属性)

写在前面 本文是依据w3c 学习轨迹,自己研习过程中记录下的笔记,仅仅供自己学习轨迹记录之用,不喜勿喷. 0 引入库 引入相应的文件: <link rel="stylesheet" href="http://code.jquery.com/mobile/1.3.2/jquery.mobile-1.3.2.min.css"> <script src="http://code.jquery.com/jquery-1.8.3.min.js&qu

mysql学习笔记之十(mysql运算符)

mysql提供的运算符包含算术运算符,比较运算符,逻辑运算符和位运算符. 算数运算符 包含:+ - * / % 1.获取各种算数运算后的结果 select 6+4 '加法', 6-4 '减法', 6*4 '乘法', 6/4 '除法', 6 div 4 '除法', 6%4 '求模', 6 mod 4 '求模'; +--+--+--+--–+--+--+--+ | 加法 | 减法 | 乘法 | 除法 | 除法 | 求模 | 求模 | +--+--+--+--–+--+--+--+ | 10 | 2

MySQL学习笔记——第2章 MySQL的安装与配置

在Windows下安装MySQL:http://jingyan.baidu.com/article/4b07be3c67853c48b380f311.html 在Linux下安装MySQL:http://blog.itblood.com/under-linux-mysql-latest-version-installation-diagram-tutorial.html

项目管理学习笔记之中的一个.项目管理综述

一.引言: 认识项目管理 三位管理学大师的三段话: 1. "在当今社会,一切都是项目,一切也将成为项目." ---- 美国项目管理协会主席保罗 2. "项目管理将站在21世纪管理舞台的中央,21世纪将进入项目管理时代!" ---- 管理学大师 Tom Peters 3. "在应付全球化的市场活动中.有两个管理将起到关键的作用. 第一个是战略管理 ,第二个管理是项目管理. 战略管理立足于企业的长远和宏观,它考虑的是一个企业核心的竞争力问题, 而项目管理是实现