首页 > 编程知识 正文

mysql数据库数据类型与操作,mysql数据库数据类型与操作

时间:2023-12-29 20:31:45 阅读:330624 作者:FTCB

本文目录一览:

mysql数据类型

数据库类型可分为层次型、网状型和关系型。

层次型数据库是把数据根据层次构造(树结构)的方法呈现;网状型数据库是采用网状原理和方法,以网状数据模型为基础建立的数据库;关系型数据库是指采用了关系模型来组织数据的数据库。

数据库的作用

1、实现数据共享:数据共享包含所有用户可同时存取数据库中的数据,也包括用户可以用各种方式通过接口使用数据库,并提供数据共享。

2、减少数据的冗余度:同文件系统相比,由于数据库实现了数据共享,从而避免了用户各自建立应用文件。减少了大量重复数据,减少了数据冗余,维护了数据的一致性。

3、保持数据的独立性:数据的独立性包括逻辑独立性(数据库中数据库的逻辑结构和应用程序相互独立)和物理独立性(数据物理结构的变化不影响数据的逻辑结构)。

4、数据实现集中控制:文件管理方式中,数据处于一种分散的状态,不同的用户或同一用户在不同处理中其文件之间毫无关系。利用数据库可对数据进行集中控制和管理,并通过数据模型表示各种数据的组织以及数据间的联系。

mysql基础数据类型118-124

#常见的数据类型

/*

数值型:

    整形

    小数:

        定点数

        浮点数

字符型:

    较短的文本:char、varchar

    较长的文本:text、blob(较长的二进制数据)

日期型:

*/

#一、整形

/*

分类:

tinyint、smallint、mediumint、int/integer、bigint

1            2                3                        4                8

特点:

    -如果不设置无符号还是有符号,默认是有符号,如果想设置无符号,需要添加unsigned关键字

    -如果插入的数值超出了整形的范围,会报out of range异常,并且插入临界值

    -如果不设置长度,会有默认的长度

    -长度代表了显示的最大宽度,如果不够会用0在左边填充,但是必须搭配zerofill使用

*/

#1.如何设置无符号和有符号

CREATE TABLE tab_int(

    t1 INT

    t2 INT ZEROFILL  【无符号】

);

#二、小数

/*

浮点型

    float(M, D)

    double(M, D)

定点型

    dec(M, D)

    decimal(M, D)

特点:

-M:整数部位+小数部位

-D:小数部位

-M和D都可以省略

如果是decimal,则M默认为10,D默认为0

如果是float和double,则会根据插入的数值的精度来决定精度

定点型的精确度较高,如果要求插入数值的精度较高如货币运算等则考虑使用

*/

CREATE TABLE tab_float (

    f1 FLOAT(5, 2)

    f2 DOUBLE (5, 2)

    f3 DECIMAL(5, 2)

)

#原则:

/*

所选择的类型越简单越好,能保存数值的类型越小越好

*/

#三、字符型

/*

较短的文本:

char

varchar

较长的文本:

text

blob(较大的二进制)

特点:

                    写法                M的意思                                         特点                       空间的耗费                    效率        

char            char(M)       最大的字符数,可以省略         固定长度的字符            比较耗费                        高

varchar      carchar(M)    最大的字符数,不可以省略    可变长度的字符            比较节省                        低

*/

CREATE TABLE tab_char(

    c1 ENUM('a','b','c')

)

CREATE TABLE tab_set(

    s1    SET ('a','b','c','d')

)

#四、日期型

特点:

                                     字节                        范围                    时区等的影响

datetime                          8                            10000-9999            不受

timestamp                        4                        1970-2038                    受

CREATE TABLE tab_date(

    t1    DATETIME,

    t2    TIMESTAMP

)

#常见约束

/*

含义:一种限制,用于限制表中的数据,为了保证表中的数据的准确和可靠性

分类:六大约束

    NOT NULL:非空,用于保证该字段的值不能为空,比如姓名、学号等

    default:默认,用于保证该字段有默认值,比如性别

    primary key:主键,用于保证该字段的值具有唯一性,并且非空,比如学号等

    unique:唯一,用于保证该字段的值具有唯一性,可以为空,比如座位号

    check:检查约束【mysql中不支持】,比如年龄、性别

    foreign key:外键,用于限制两个表的关系,用于保证该字段的值必须来自于主表的关联列的值,在从表添加外键约束,用于引用主表中某列的值,比如员工表的部门编号,员工表的工种编号

添加约束的时机:

    1.创建表时

    2.修改表时

约束的添加分类:

    列级约束:

        六大约束语法上都支持,但外键约束没有效果

    表级约束:

        除了非空、默认,其他的都支持

*/

CREATE TABLE 表名(

    字段名    字段类型    列级约束,

    表级约束

)

#一、创建表时添加约束

/*

语法:

直接在字段名和类型后面追加 约束类型即可

只支持:

*/

#1.添加列级约束

create table stuinfo (

    id int primary key,  #主键

    stuName  varchar(20) not null,   #非空

    gender char(1)  check(gender='男' OR gender ='女'),  #检查约束

    seat int unique,  #唯一约束

    age  int  default  18,  #默认约束

    majorId int foreign key references major (id)  #外键

)

create table major (

    id int primary key,

    majorName  varchar (20)

)

desc stuinfo   #查看表结构

show index from stuinfo  #查看stuinfo表中所有的索引,包括主键、外键、唯一

#2、添加表级约束

create table stuinfo (

     id int

    stuName  varchar(20) 

    gender char(1) 

    seat int,

    age  int  , 

    majorId int

    constraint pk primary key (id),  #主键

    constraint  uq unique (seat),  #唯一键

    constraint  ck check (gender = '男' or gender = '女'),   #检查

    constraint  fk_stuinfo_major foreign key(majorid) references major(id)  #外键

)

mysql数据库

MySQL数据库一般指MySQL,MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发。

mysql是目前网站以及APP应用上用得较多的一个开源的关系型数据库系统,可以对数据进行保存,分段化的数据保存,也可以对其数据进行检索,查询等功能的数据库。

默认的mysql数据库中存有一个库这个就是mysql的系统数据库,可以对其保存系统的数据包括mysql数据库的信息,数据库root账号,普通账号,以及数据库的名称,还有数据库的一些表还有一些数字型的数据类型结构都会有所保存。

mysql数据库的优点

(1)MySQL数据库是用C和C++语言编写的,并且使用了多种编辑器进行测试,以保证源码的可移植性。

(2)支持多个操作系统例如:Windows、Linux、Mac OS等等。

(3)支持多线程,可以充分的利用CPU资源。

(4)为多种编程语言提供API,包括C语言、Java、PHP、Python语言等。

(5)MySQL优化了SQL算法,有效的提高了查询速度。

(6)MySQL内提供了用于管理,检查以及优化数据库操作的管理工具。

(7)它能够作为一个单独的应用程序应用在客户端服务器网络环境中,也可以作为一个库嵌入到其他的软件中并提供多种语言支持。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。