MySQL有什么推荐的学习书籍

MySQL有什么推荐的学习书籍,第1张

1、《MySQL技术内幕:InnoDB存储引擎》

《MySQL技术内幕:InnoDB存储引擎》的作者是姜承尧。本书从源代码的角度深度解析了InnoDB

的体系结构、实现原理、工作机制,并给出了大量最佳实践。

2、《MySQL完全手册》

《MySQL完全手册》详细介绍了如何使用可定制的MySQL数据库管理系统支持健壮的、可靠的、任

务关键的应用程序。

3、《深入浅出mysql》

《深入浅出mysql》从数据库的基础、开发、优化、管理维护4个方面对MySQL进行了详细的介绍,

其中每一部分都独立成篇。

基础篇主要适合于MySQL的初学者,内容包括MySQL的安装与配置、SQL基础、MySQL支持的数

据类型、MySQL中的运算符、常用函数、图形化工具的使用等。

4、《 数据库索引设计与优化》

本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题。特别需要说明的是,MySQL

支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同。

5、《高性能MySQL》

《高性能MySQL》是分享MySQL实用经验的图书。它不但可以帮助MySQL初学者提高使用技巧,

更为有经验的MySQL DBA指出了开发高性能MySQL应用的途径。

 扩展资料:

《MySQL技术内幕:InnoDB存储引擎》是国内目前唯一的一本关于InnoDB的著作,由资深MySQL

专家亲自执笔,中外数据库专家联袂推荐,权威性毋庸置疑。

它能为读者设计和管理高性能、高可用的数据库系统提供绝佳的指导。注重实战,全书辅有大量的

案例,可 *** 作性极强。全书首先全景式地介绍了MySQL独有的插件式存储引擎,分析了MySQL的各

种存储引擎的优势和应用环境。

参考资料:百度百科——MySQL技术内幕:InnoDB存储引擎

#常见的数据类型

/*

数值型:

    整形

    小数:

        定点数

        浮点数

字符型:

    较短的文本: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 -h192.168.110.xxx -uroot -p -P 3306 (回车后输入密码,即可进入mysql)

1、显示 数据库 列表

mysql>show databases(注:MySQL语句分隔符为“;”)

默认有三个数据库:information_schema、mysql和test。information_schema库为MySQL默认字典库,mysql库很重要它里面有MySQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行 *** 作。

2、显示库中的数据表:

mysql>use mysql;(指定mysql库)

mysql>show tables

3、显示数据表的结构:

mysql>describe yourtablename/ mysql>desc yourtablename

4、建库:

mysql>create database yourdbname

5、建表:

mysql>create table yourtablename (columnname colunmtype,...);

6、删库和删表:

mysql>drop database yourdbname

mysql>drop table yourtablename;

7、将表中记录清空:

mysql>delete from yourtablename

8、显示表中的记录:

mysql>select * from yourtablename

9、举个例子:一个建库和建表以及插入数据的实例

mysql>create database world//建立库world

mysql>use world//打开库world

mysql>create table city //建立表city

(IDint(3) not null auto_increment ,

Name char(30) notnull default '',

CountryCode char(3) not null default '',

District char(20) not null default '',

Population integer not null default '0',

Primary key ('ID') )//建表结束

//以下为插入字段

mysql>insert intocity values('','Kabul','AFG','Kabol','1780000')

mysql>insert intocity values('','Beijing','CHN','Beijing','1780001')

出处:mysqlpub.com ,不断完善更新中。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5905297.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-07
下一篇 2023-03-07

发表评论

登录后才能评论

评论列表(0条)

保存