MySQL数据操作管理示例详解

 更新时间:2022年09月23日 08:45:57   作者:方片6  
MySQL是最流行的关系型数据库管理系统,在WEB应用方面MySQL是最好的应用软件之一。在本篇中,会让大家快速掌握MySQL的基本操作,并轻松使用MySQL数据库

一、查看表和查看表的定义

SHOW TABLE 表名
DESC 表名;
DESCRIBE  表名

二、删除表

DROP TABLE [IF EXISTS ] 表名;

如果表USER存在,删除表USER

DROP TABLE IF EXISTS USER;

三、创建表

CREATE   TABLE [ IF NOT EXISTS ]    `表名`   (
	`字段名1`   列类型 [ 字段属性 | 约束]  [ 索引 ] [注释] ,
	`字段名2`   列类型 [ 字段属性 | 约束]  [ 索引 ] [注释] , 
	… …
	`字段名n`   列类型 [字段属性 | 约束]  [ 索引 ] [注释] 
)  [  表类型 ] [ 表字符集 ] [注释] ;

四、表类型

使用MyISAM: 节约空间及相应速度,适合以访问为主的应用。

使用InnoDB: 安全性,事务处理及多用户操作数据表。

五、修改表

//修改表名
ALTER TABLE 旧表名  RENAME AS  新表名
//添加字段
ALTER TABLE 表名   ADD 字段名   列类型 [ 属性 ] 
// 修改列的数据类型
ALTER TABLE 表名   MODIFY 字段名   列类型 [ 属性 ]
//修改列的数据类型及名称
ALTER TABLE 表名  CHANGE 旧字段名 新字段名  列类型 [ 属性 ]
//删除字段
ALTER TABLE 表名   DROP  字段名

六、完整性

数据完整性 = 数据的精确性 + 数据的可靠性

1、数据完整性

1.实体完整性

保证表中所有的行唯一

2.域完整性

数据库表中的列必须满足某种特定的数据类型或约束 取值范围 精度

3.引用完整性

保证主关键字 //被引用表 \ 和外部关键字 //引用表\ 之间的参照关系

涉及两个或两个以上表数据的一致性维护

2、使用约束实现数据完整性

3、在数据表上添加约束

//设置唯一约束
ALTER TABLE 表名 ADD CONSTRAINT 约束名  UNIQUE(列名);
//主键
//如果两列或多列组合起来唯一地标识表中的每个行,则该主键叫做“复合主键”
ALTER TABLE 表名 ADD CONSTRAINT 约束名  PRIMARY KEY(列名1,列名2,…列名n);
//设置外键约束
ALTER TABLE 从表名 ADD CONSTRAINT 约束名  FOREIGN KEY(从表的列名) REFERENCES 主表名(主表的列名) 

设置外键约束的注意事项:

1.主表中的字段必须为主键。

2.从表中的外键列和主表中的主键列的数据类型要保持一致,和字段名无关。

3.主表和从表的表类型为InnoDB。

4、删除约束

//删除主键约束
ALTER TABLE 表名  DROP PRIMARY KEY;
//删除唯一约束
ALTER TABLE 表名  DROP KEY 唯一约束名;
//删除外键约束
ALTER TABLE 表名  DROP FOREIGN KEY 外键约束名;

七、添加数据

//插入单行数据
INSERT INTO  表名  [ ( 字段1, 字段2, 字段3, … ) ]  VALUES  ( 值1, 值2, 值3, …);
//插入多行数据
INSERT INTO  表名  [ ( 字段1, 字段2, 字段3, … ) ]  VALUES  ( 值1, 值2, 值3, …),( 值1, 值2, 值3, …),…;
//将查询结果插入到新表中
CREATE TABLE  新表名  ( SELECT 字段1, 字段2, 字段3, … FROM 原表)

八、修改数据

UPDATE   表名    SET   column_name = value  [ ,  column_name2 = value2, …. ]  [ WHERE   condition ];
//1.column_name 为要更改的字段名。
//2.value 为修改后的数据,可以为变量、具体值、表达式或者嵌套的SELECT结果。
//3.多个字段之间用逗号隔开。
//4.提供的修改数据必须符合数据完整性的要求。
//5.condition为筛选条件,如不指定则修改该表的所有列数据。

九、删除数据

DELETE FROM   表名   [ WHERE   condition ];
//1.DELETE语句删除的是整条记录,不会只删除单个列。
//2.condition为筛选条件,如不指定则修改该表的所有列数据。
TRUNCATE TABLE   表名;
//1.TRUNCATE TABLE 删除表中所有的行。
//2.TRUNCATE TABLE不能用于有外键约束引用的表。
//3.同时删除MySQL内的计数器,即自动增加的计数器

十、SQL语句中的运算符

算数运算符

比较运算符

逻辑运算符

到此这篇关于MySQL数据操作管理示例详解的文章就介绍到这了,更多相关MySQL数据操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL中日期和时间戳互相转换的函数和方法

    MySQL中日期和时间戳互相转换的函数和方法

    这篇文章主要介绍了MySQL中日期和时间戳互相转换的函数和方法,本文分别讲解了时间戳转换成日期的方法和把日期转换为时间戳的方法,需要的朋友可以参考下
    2015-06-06
  • 关于MySQL查询语句的优化详解

    关于MySQL查询语句的优化详解

    这篇文章主要介绍了MySQL查询语句的优化方法,分别介绍了子查询优化,分页查询优化以及排序查询优化,对学习有一定的帮助,需要的小伙伴可以参考一下
    2023-04-04
  • MySQL错误“Specified key was too long; max key length is 1000 bytes”的解决办法

    MySQL错误“Specified key was too long; max key length is 1000 b

    今天在为数据库中的某两个字段设置unique索引的时候,出现了Specified key was too long; max key length is 1000 bytes错误
    2010-08-08
  • MySQL中日期比较时遇到的编码问题解决办法

    MySQL中日期比较时遇到的编码问题解决办法

    这篇文章主要介绍了MySQL中日期比较时遇到的字符集问题解决办法,本文遇到的问题是date_format函数和timediff函数之间比较时,编码问题导致出错,本文使用convert()函数解决了这个问题,需要的朋友可以参考下
    2014-07-07
  • linux安装mysql 8.0.x的完整步骤

    linux安装mysql 8.0.x的完整步骤

    这篇文章主要给大家介绍了关于linux安装mysql 8.0.x的完整步骤,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • 6G数据库的导入 报各种错误的解决办法

    6G数据库的导入 报各种错误的解决办法

    今天看到一高人的mysql数据库达到了6G左右,导入都是个问题,上传也挺麻烦的,这里特分享下,方便需要的朋友
    2013-01-01
  • mysql下为数据库设置交叉权限的方法

    mysql下为数据库设置交叉权限的方法

    由于 SupeSite 需要调用 Discuz! 和 UCHome 的数据,所以如果它们不安装在同一个数据库,SupeSite 的数据库用户必须要对 Discuz! 和 UCHome 的数据库有读取、修改、删除等权限。
    2011-07-07
  • mysql用户管理和权限设置方式

    mysql用户管理和权限设置方式

    这篇文章主要介绍了mysql用户管理和权限设置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Mysql中where与on的区别及何时使用详析

    Mysql中where与on的区别及何时使用详析

    MySQL当中的限制条件可以使用on或者where,两者在不同的情况下具有不同而意义,这篇文章主要给大家介绍了关于Mysql中where与on的区别及何时使用的相关资料,需要的朋友可以参考下
    2021-08-08
  • mysql性能监控工具Innotop简介及配置

    mysql性能监控工具Innotop简介及配置

    INNOTOP是一个通过文本模式显示MySQL和InnoDB的监测工具。INNOTOP是用PERL语言写成的,这使它能更加灵活的使用在各种操作平台之上,它能详细的的监控出当前MYSQL和INNODB运行的状态,以DBA根据结果,可以合理的优化MYSQL,让MYSQL更稳定更高效的运行。
    2014-08-08

最新评论