做互联网网站赚钱吗舟山网站网站建设

当前位置: 首页 > news >正文

做互联网网站赚钱吗,舟山网站网站建设,wordpress个人博客下载,企业建站公司哪里有目录 前言 一.数据库构成 1.1 表 1.2 关系 1.3 索引 1.4 查询语言 1.5 数据库管理系统 二.数据类型 2.1 整数 2.2 浮点 2.3 日期与时间 2.4 字符串 三.约束条件 3.1 主键约束 3.2 唯一约束 3.3 外键约束 3.4 非空约束 3.5 默认值约束 总结 前言 数据库是…目录 前言 一.数据库构成 1.1 表 1.2 关系 1.3 索引 1.4 查询语言 1.5 数据库管理系统 二.数据类型 2.1 整数 2.2 浮点 2.3 日期与时间 2.4 字符串 三.约束条件 3.1  主键约束 3.2  唯一约束 3.3  外键约束 3.4 非空约束 3.5 默认值约束 总结 前言 数据库是现代信息技术的重要组成部分它在各个领域都有广泛应用因此数据库专业人才的需求也非常高。学习数据库可以为你提供广阔的就业前景和良好的薪资待遇同时也能够提升数据管理、数据分析和软件开发等多方面的技能。 本篇文章通过数据库构成数据类型和约束条件这三个部分的内容来让你了解数据库的基础知识。详细内容请看正文。 一.数据库构成 1.1 表 表Table用于组织和存储数据的矩阵结构。每个表包含一组字段Columns和记录Rows字段定义了数据的类型和属性记录则是具体的数据实例。 示例代码 CREATE TABLE students (id INT PRIMARY KEY,name VARCHAR(50),age INT,gender VARCHAR(10) ); 1.2 关系 关系Relationship通过公共字段主键和外键连接不同表之间的数据关联。关系可以是一对一、一对多或多对多。 示例代码 CREATE TABLE courses (id INT PRIMARY KEY,name VARCHAR(50),instructor_id INT,FOREIGN KEY (instructor_id) REFERENCES instructors(id) ); 1.3 索引 索引Index用于提高数据的检索效率特别是对大型数据集进行快速搜索和排序。索引基于一个或多个列的值创建。 示例代码 CREATE INDEX idx_students_name ON students(name); 1.4 查询语言 查询语言SQL用于与数据库进行交互执行数据操作和检索。常见的查询语言是结构化查询语言SQL。 示例代码 SELECT * FROM students WHERE age 20; 1.5 数据库管理系统 数据库管理系统DBMS用于管理和操作数据库的软件。常见的DBMS包括MySQL、Oracle和SQL Server等。 示例代码MySQL CREATE DATABASE mydb; USE mydb; 二.数据类型
2.1 整数 整数类型一共有 5 种包括 TINYINT、SMALLINT、MEDIUMINT、INTINTEGER和 BIGINT。以下是MySQL中常见的日期和时间数据类型 1. TINYINT用于存储非常小的整数范围是-128到127有符号或0到255无符号。占用空间1字节。 2. SMALLINT用于存储较小的整数范围是-32768到32767有符号或0到65535无符号。占用空间2字节。 3. MEDIUMINT用于存储中等大小的整数范围是-8388608到8388607有符号或0到16777215无符号。占用空间3字节。 4. INTINTEGER用于存储常见的整数范围是-2147483648到2147483647有符号或0到4294967295无符号。占用空间4字节。 5. BIGINT用于存储大整数范围是-9223372036854775808到9223372036854775807有符号或0到18446744073709551615无符号。占用空间8字节。 这些整数数据类型可以根据需要选择有符号可包含正负值或无符号仅包含非负值。有符号整数可以表示正负整数而无符号整数只能表示非负整数。 示例代码 CREATE TABLE employees (id INT PRIMARY KEY,age TINYINT UNSIGNED,salary BIGINT NOT NULL,tenure SMALLINT ); 2.2 浮点 浮点数和定点数类型的特点是可以 处理小数 你可以把整数看成小数的一个特例。因此浮点数和定点数的使用场景比整数大多了。 MySQL支持的浮点数类型分别是FLOAT、DOUBLE、REAL。以下是MySQL中常见的日期和时间数据类型 1. FLOAT(M, D)用于存储单精度浮点数。M表示总位数精度D表示小数位数标度。FLOAT数据类型可以存储大约7位精度。 2. DOUBLE(M, D)用于存储双精度浮点数。M表示总位数精度D表示小数位数标度。DOUBLE数据类型可以存储大约15位精度。 3. DECIMAL(M, D)用于精确的十进制浮点数。M表示总位数D表示小数位数。DECIMAL数据类型在存储和计算时具有固定的精度。 这些浮点数数据类型可以根据需要来选择合适的精度和范围。FLOAT和DOUBLE数据类型在存储大量数据时占用的空间相对较小但存在一些舍入误差。DECIMAL数据类型提供了准确的十进制计算但占用的存储空间相对较大。 示例代码 CREATE TABLE products (id INT PRIMARY KEY,price FLOAT(8, 2),weight DECIMAL(6, 3) ); 2.3 日期与时间 表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。每个时间类型有一个有效值范围和一个零值当指定不合法的MySQL不能表示的值时使用零值。以下是MySQL中常见的日期和时间数据类型 1. DATE用于存储日期值格式为YYYY-MM-DD。 2. TIME用于存储时间值格式为HH:MM:SS。 3. DATETIME用于存储日期和时间值格式为YYYY-MM-DD HH:MM:SS。 4. TIMESTAMP用于存储日期和时间戳值。存储的范围为1970-01-01 00:00:01到2038-01-19 03:14:07以UTC时间为基准。 5. YEAR用于存储年份值格式为YYYY。 示例代码 CREATE TABLE events (id INT PRIMARY KEY,event_date DATE,event_time TIME,event_datetime DATETIME,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); 2.4 字符串 MySQL数据库提供了多个字符串String数据类型用于存储和处理文本和字符数据。以下是MySQL中常见的字符串数据类型 1. CHAR用于存储固定长度的字符串。在创建表时需要指定字符的最大数量。CHAR类型的字符串在存储时会被自动填充空格因此它适合存储长度相等的数据。 2. VARCHAR用于存储可变长度的字符串。在创建表时需要指定字符的最大数量。VARCHAR类型的字符串只会占用实际使用的存储空间适合存储长度不等的数据。 3. TEXT用于存储较长的文本数据最大容量为65,535个字符。 4. ENUM用于存储枚举值中的一个。ENUM类型提供给定选项的固定集合您可以根据需要定义不同的选项。 5. SET用于存储SET值中的一个或多个。SET类型提供给定选项的可变集合您可以根据需要定义多个选项。 示例代码 CREATE TABLE users (id INT PRIMARY KEY,first_name VARCHAR(50),last_name VARCHAR(50),email CHAR(100),bio TEXT ); 注意 CHAR(M) 类型一般需要预先定义字符串长度。如果不指定(M)则表示长度默认是1个字符。 VARCHAR(M) 定义时 必须指定 长度M否则报错。char(n) 和 varchar(n) 中括号中 n 代表字符的个数并不代表字节个数比如 CHAR(30) 就可以存储 30 个字符。 三.约束条件 3.1  主键约束 主键约束PRIMARY KEY用于唯一标识表中的每一行数据。主键与记录之间的关系如同身份证和人之间的关系他们是一一对应的。以下是MySQL中主键约束的一些重要特点 1. 主键的值是唯一的主键列的值在整个表中必须是唯一的即每一行都有一个不同的主键值。 2. 主键不允许NULL值主键列的值不能为NULL确保每一行都有一个有效的主键值。 3. 主键的唯一索引MySQL会自动为定义主键约束的列创建一个唯一索引以提高查询效率。 4. 主键可以由一个或多个列组成在创建表时可以选择将多个列作为主键。这种情况下这些列的组合必须是唯一的。 5. 主键的自动递增AUTO_INCREMENT通常情况下我们会将主键列定义为自动递增的。这意味着MySQL会自动为主键列生成唯一的、递增的值。 示例代码 CREATE TABLE users (id INT PRIMARY KEY,username VARCHAR(50),email VARCHAR(100) ); 在上述示例中id列被定义为主键它将唯一标识users表中的每一行。 通过使用主键约束可以确保表中的每一行都有一个唯一的标识帮助保持数据的一致性和完整性。主键还可以作为关联表之间的连接点用于建立表之间的关系。 3.2  唯一约束 唯一约束UNIQUE用于确保某个列或一组列中的值是唯一的。唯一约束可以包含NULL值但每个非NULL值都必须是唯一的。以下是MySQL中唯一约束的一些关键特点 1. 唯一值的限制唯一约束确保在指定的列中每个值只能出现一次并且不允许重复。这使得该列或组合列具有唯一性。 2. 包含NULL值唯一约束允许在列中包含NULL值。NULL值被视为特殊值因此在列中可以有多个NULL值但非NULL值必须唯一。 3. 创建唯一索引MySQL会自动为唯一约束的列创建唯一索引以确保检索和查询的高效性。 4. 可以定义在单个列或多个列上可以在单个列上定义唯一约束也可以在多个列的组合上定义。对于多列的组合这些列的组合值必须是唯一的。 示例代码 CREATE TABLE users (id INT,username VARCHAR(50) UNIQUE,email VARCHAR(100) UNIQUE ); 在上述示例中username和email列都被定义为唯一约束确保表中每个用户的用户名和电子邮件地址都是唯一的。 需要注意的是通过使用唯一约束可以在列或组合列上强制实施数据的唯一性。这有助于避免数据重复或重复插入并维护数据的一致性。 3.3  外键约束 外键约束FOREIGN KEY用于关联两个表确保外键列中的值存在于关联表的主键列中。外键约束可以用于维护表之间的引用完整性。以下是MySQL中外键约束的一些重要特点 1. 关联表之间的关系外键约束用于定义表之间的关系其中一个表中的列引用了另一个表的主键列。这种关系称为引用关系。 2. 父表和子表在关系中包含主键列的表称为父表而包含外键列的表称为子表。 3. 引用完整性外键约束确保在子表中的外键列中的值存在于父表的主键列中。这样可以防止在子表中插入无效的引用值。 4. 级联操作在定义外键约束时可以选择定义级联操作。这意味着在父表中进行更新或删除操作时MySQL将自动更新或删除相关的子表中的行。 示例代码 CREATE TABLE customers (id INT PRIMARY KEY,name VARCHAR(100) );CREATE TABLE orders (id INT PRIMARY KEY,customer_id INT,order_date DATE,FOREIGN KEY (customer_id) REFERENCES customers(id) ); 在上述示例中orders表中的customer_id列被定义为外键引用了customers表中的id列。这样就建立了customers表和orders表之间的关联。 3.4 非空约束 非空约束NOT NULL用于确保某个列中的值不为空即不允许NULL值。以下是MySQL中非空约束的一些关键特点 1. 强制不为空值非空约束要求在指定的列中插入的值不能为NULL。这意味着该列不能没有值必须包含一个有效的值。 2. 默认情况下允许为NULL在创建表时如果没有显式地指定非空约束那么表中的列默认情况下是允许为NULL的。 3. 在插入或更新时进行验证当尝试插入或更新某一行的数据时MySQL会自动验证非空约束确保所要插入或更新的列不为空。 4. 阻止插入或更新空值如果尝试插入或更新数据时提供了NULL值而该列具有非空约束MySQL将拒绝该操作并抛出相应的错误或警告。 示例代码 CREATE TABLE employees (id INT PRIMARY KEY,name VARCHAR(100) NOT NULL,age INT NOT NULL,department VARCHAR(50) ); 在上述示例中name和age列被定义为非空约束这表示在插入或更新数据时这两个列必须包含非NULL的值。 3.5 默认值约束 默认值约束DEFAULT用于在插入数据时如果未提供该列的值则将使用默认值。以下是MySQL中默认值约束的一些关键特点 1. 设置默认值默认值约束用于指定列在插入时应具有的默认值。可以使用各种数据类型的字面值作为默认值例如字符串、数字、NULL等。 2. 针对NULL值的默认值当列的默认值设置为NULL时如果未提供明确值或NULL以外的值MySQL将自动插入NULL作为默认值。 3. 指定默认值的位置在创建表时可以在列定义之后使用DEFAULT关键字来指定默认值。也可以通过ALTER TABLE语句在已存在的表上添加默认值。 4. 修改默认值可以随时通过ALTER TABLE语句修改现有列的默认值。 示例代码 CREATE TABLE employees (id INT PRIMARY KEY,name VARCHAR(100) DEFAULT N/A,age INT DEFAULT 0,department VARCHAR(50) DEFAULT NULL ); 在上述示例中name列的默认值设置为字符串N/Aage列的默认值设置为整数0department列的默认值设置为NULL。 通过使用默认值约束可以确保在插入数据时如果未显式提供值那么将使用默认值填充列从而简化了对那些常见的默认值的重复输入提高了数据插入的效率和简洁性。 总结 总的来说数据库是一个组织和存储数据的系统。它可以被视为一个电子文件柜用于收集、管理和提供对数据的访问。数据库通常由数据表、记录和字段组成这些表用于存储不同类别的数据并通过键值关系相互连接。 关注点赞收藏希望友友们能一键三连哦