广告
返回顶部
首页 > 资讯 > 数据库 >MySQL数据库管理2
  • 129
分享到

MySQL数据库管理2

2024-04-02 19:04:59 129人浏览 泡泡鱼
摘要

te  database   db102; create  table db102.t1(name char(6),age  int(3));in

te  database   db102; create  table db102.t1(name 


char(6),age  int(3));


insert  into  db102.t1  values("jerry",91024);


create  table db102.t2(id  int(2)  zerofill,name char(6));


insert into  t2  values(3,"tom"),(7,"jim"),(9,"lucy"),


(12,"bob"),(191,"alic");


select  * from t2;


可以使用2位数字给year类型的字段赋值:

01~69   20XX

70~99   19XX

00          0000

create table   t3 (name char(10),s_year  year);

insert  into   t3  values("bob",01),("jim",69),("lucy",70);

select  * from  t3;


日期时间类型 datetime  和  timestamp 区别?

 

create  table   t4   (

meetting  datetime,

reg_t   timestamp

);


insert into  t4  values


(20170523093900,20170523093900);

insert into  t4(meetting)  values(20170529093058);

insert into  t4(reg_t)  values(20190529094058);

select  * from t4;

+++++++++++++++++++++++++

day02

Mysql 索引

1  什么索引?(建在表中的字段上)

相当于 "书的目录"

5000页

目录  1~100    正文  101 ~5000

笔画    9  2000------2010

部首

拼音


删除  添加  修改

stuinfo                      数库目录 /stuinfo.frm     .ibd

name   age    sex  class

jim

jerry

abob

lili

han×××


select  * from  stuinfo where class="1702";



2 索引的优点与缺点?

优点:加快查询的速度

缺点: 占用物理存储空间,会减慢对表写操作的速度。

++++++++++++++++++++++++++++++++++

mysql索引类型:

INDEX:普通索引*

UNIQUE:唯一索引

FULLTEXT:全文索引

PRIMARY KEY:主键 *

FOREIGN KEY:外键*



使用INDEX:普通索引

索引的使用规则:

一个表中可以有多个INDEX字段

字段的值允许有重复,切可以赋NULL值

经常把做查询条件的字段设置为INDEX字段

INDEX字段的KEY标志是MUL


创建index索引

建表是创建

create  table   t5(

name  char(10),

age  int(2),

sex  enum("boy","girl"),

index(name),

index(sex)

);

把已有的字段设置为index字段

mysql> create  index  索引名  on  表名(字段名);


查看

desc  表名;   Key

show  index  from 表名; 

Table: t1

Key_name: aaa

Column_name: name

Index_type: BTREE      (B+TREE   HASH)

                     二叉树

                     1~10

              1-5        6-10


删除

drop  index   索引名 on 表名;

++++++++++++++++++++++++

使用PRIMARY KEY:主键 *

使用规则?

一个表中只能有一个primary  key字段

对应的字段值不允许有重复,且不允许赋NULL值

主键字段的KEY标志是PRI


如果有多个字段都作为PRIMARY KEY,称为复合主键,必须一


起创建。

和auto_increment一起使用让字段的值自动增长

 

经常把表中能够唯一标识记录的字段设置为主键字段[记录编号


字段]


stu_id    name    age 

   1          bob      19

   2         lucy       18

   3         alic        21

   4         jerry      19                                                             


create  table   t9(

stu_id  int(2) primary key  auto_increment,

name  char(10),

age   tinyint(2)  unsigned

);


insert into   t9(name,age)values("bob",21);

insert into   t9(name,age)values("lucy",21);

insert into   t9(name,age)values("lili",21);

select  * from t9;


create  table   t6(

name  char(10),

age  int(2),

sex  enum("boy","girl"),

primary key(name)

);

create  table   t7(

name  char(10)  primary key,

age  int(2),

sex  enum("boy","girl")

);


把表中已有字段设置为主键

alter  table   表名  add  primary key ( 字段名);


复合主键:

只有做符合主键的多个字段的值不同时重复就可以


PRI           PRI

cip            port    status

 1.1.1.1     21        deny

1.1.1.1     25        allow

 2.1.1.1     25        deny




create  table  t8(

cip  varchar(15),

port  smallint(2),

status  enum("allow","deny"),

primary key (cip,port)

);


insert into  t8

values

("1.1.1.1",21,"deny"),

("1.1.1.1",25,"allow"),

("2.2.3.2",25,"deny");



删除主键

alter  table   表名  drop   primary key ;

+++++++++++++++++++++++++++++++

unique 唯一索引:

一个表中可以有多个UNIQUE字段

对应的字段值不允许有重复

UNIQUE字段的KEY标志是UNI

UNIQUE字段的值允许为NULL,当将其修改为不允许为NULL


,则此字段限制与主键相同


create  table   t10(

name  char(10),

shf_id   varchar(18),

ks_num   char(8),

age  int(2),

sex  enum("boy","girl"),

index(name),

unique(shf_id),

unique(ks_num)

);


create unique index  索引名 on  表 (字段名);


drop  index    索引名 on  表;

mysql> drop index  shf_id on t10;


+++++++++++++++++++++++++++++

FOREIGN KEY:外键

功能:给当前表的字段赋值时,字段的值,只能在另一个表的字


段值里选择。

使用规则?

表的存储引擎必须是innodb

字段类型必须匹配

被参考字段的必须是索引的一种(通常是primary key )


财务表cwb

create table cwb(

cwb_id  int(2) primary  key  auto_increment,

name    varchar(15),

pay   float(7,2)

)engine=innodb;


create  table  bjb(

bjb_id int(2),

name varchar(15),

age  tinyint(2),

foreign key(bjb_id)  references  cwb(cwb_id)  on update  


cascade  on delete cascade

)engine=innodb;


desc  bjb;

show create table bjb;


 insert into  cwb(name,pay) values("bob",20000),


("lucy",20000);



insert into  bjb   values(1,"alic",23);

update  cwb  set  cwb_id=8  where  cwb_id=2;

delete from cwb where cwb_id=3;


删除外键

show create  table 表名;#查看建表命令

alter  table  表 drop    foreign  key   外键名;


在已有表里添加外键。

alter  table  表 add  foreign key(字段名)  references  表名(


字段名)  on update  cascade   on delete cascade;


alter  table   bjb  add   foreign  key(bjb_id)  references  


cwb(cwb_id)  on update  cascade   on delete cascade;


++++++++++++++++++++++++++++++++

二、mysql存储引擎


mysql服务的工作过程:

连接池

sql接口

分析器

优化器    select   insert  update  delete

查询缓存

存储引擎

文件系统: 硬盘 (/var/lib/mysql)

管理工具:安装服务软件包时,自带的命令



1 什么存储引擎?

是mysql数据库服务软件自带程序 ,是表的处理器,不同的处理


器有不同的功能和数据存储方式。



2 查看存储引擎?

查看表使用的存储引擎   show  create  table  表名;


查看数据库服务默认使用的存储引擎show engines;

 InnoDB              DEFAULT 


3设置存储引擎

设置表使用的存储引擎

create  table  表名(字段名列表)engine=存储引擎;


设置数据库服务默认使用的存储引擎

vim /etc/my.cnf

[mysqld]

validate_passWord_policy=0

validate_password_length=6

default-storage-engine=myisam

:wq

# systemctl stop mysqld

# systemctl start mysqld

#mysql  -uroot  -p123456

mysql> show engines;


4  常用存储引擎的特点

myisam

表级

不支持事务  和 事务回滚  

外键

表.frm  表结构 

表.MYD  表记录 select  * from  表;

表.MYI   表索引  


innodb

行级锁

支持事务  和 事务回滚

支持外键

表.frm  表结构

表.ibd  表记录+表索引


什么事务?对数据库做访问时,从开始连接到断开连接 过程称作


事务。



插卡  提示输入密码  -->登录成功

转账    接收卡号   

           金额         5w

                                确认  

                               转账中......     成功

退卡


事务回滚? 事务执行过程,任意一步执行失败,还原之前所有的


操作。


事务日志文件

/var/lib/mysql/

ib_logfile0

ib_logfile1  

ibdata1


锁: 解决并发访问冲突问题


读锁                   myisam

select    *  from  t1  where  id>=10;

                          innodb

写锁

update

insert

delete

                    innodb

pc1   update  t1  set  name="tom"  where  name="jim";

pc2   update  t1  set  name="lucy"  where  name="jim";



行级锁: 客户端访问数据库时,只给sql命令操作的行加锁。

表级锁:客户端访问数据库时,给sql命令操作的表加锁

+++++++++++++++++++

5 工作中建表时,如何决定表使用的存储引擎

写操作多的表适合使用innodb存储引擎

查询操作多的表适合使用myisam存储引擎


您可能感兴趣的文档:

--结束END--

本文标题: MySQL数据库管理2

本文链接: https://www.lsjlt.com/news/39248.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL数据库管理2
    te  database   db102; create  table db102.t1(name char(6),age  int(3));in...
    99+
    2022-10-18
  • 2 数据库和表的管理 步骤
     2.sqlserver 数据库和表的管理防伪码:书山有路勤为径 学海无涯苦作舟 实验一:实验环境:公司安装了SQL SERVER 2008企业版,现在完成如下任务:1.创建一个名为benet的数...
    99+
    2022-10-18
  • MySQL数据库管理
    SQL语句概述 SQL语言 是Structured Query Language的缩写,即结构化查询语言 是关系型数据库的标准语言 用于维护管理数据库,如数据查询、数据更新、访问控制、对象管理等功能 S...
    99+
    2022-10-18
  • 数据库课程设计-图书馆管理系统(2.数据库实现-基于mysql)
    如果对你有帮助,可以给卑微的博主留个赞、关注、收藏   (不是)  (骗一下数据,说不定以后面试就过了,拜谢) 好像有读者说现在不要积分的资源也要vip才能下,如果下不了可以留邮箱到评论区或者私聊,我也把资源放到github了,地址如下: ...
    99+
    2023-09-10
    数据库 mysql 课程设计
  • 如何管理mysql数据库
    管理mysql数据库的方法可以打开mysql脚本,输入密码登录,通过以下命令进行管理:查看一下数据库列表:“# show databases;”进入某个数据库:“ # use databaseName;”查看数据库的表项:“#sh...
    99+
    2022-10-22
  • MySQL 服务和数据库管理
    目录1、启动和关闭服务指令1.1windows下Mysql5.7官方MSI安装地址1.2、windows下1.3、linux下1.4、windows下cmd窗体进入mysql:1.4...
    99+
    2022-11-12
  • MySQL数据库的基本管理
    概述MySQL是一种开放源代码的关系型数据库管理系统(RDBMS),使用最常用的数据库管理语言--结构化查询语言(SQL)进行数据库管理。MySQL是开放源代码的,因此任何人都可以在General Publ...
    99+
    2022-10-18
  • MySQL数据库的权限管理
    Mysql权限系统非常重要,但同时又是一个很多开发者或管理者所忽略的。权限分配不但,将会造成难以挽回的悲惨后果。我之前所在一家公司,关于数据库权限这块就完全不重视,所有开发者都有线上系统的最高权限。想想看,...
    99+
    2022-10-18
  • MySQL数据库及表的管理
    库管理1.创建数据库mysql> help create database; CREATE {DATABASE | SCHEMA}&nbs...
    99+
    2022-10-18
  • MYSQL数据库管理之权限管理解读
    目录一、mysql权限简介1.MYSQL到底都有哪些权限呢?2.MYSQL的权限如何分布二、MYSQL权限经验原则三、MYSQL权限实战1.GRANT命令使用说明2.创建一个超级用户3.创建一个网站用户(程序用户)4.创...
    99+
    2023-03-20
    MYSQL数据库管理 MYSQL权限管理 MYSQL权限
  • Mysql入门基础(2)-->Mysql数据库安装
    第二章      Mysql数据库安装声明数据库和实例: 在数据库领域中有两个词很容易混淆,它们就是“实例“和数据库(database).数据库:在物理操作...
    99+
    2022-10-18
  • MySQL数据库用户授权管理
    一、用户授权1、注意事项:-  MySQL数据库服务器搭建好之后,放在独立的房间里或者是IDC机房,MySQL数据库服务默认只允许数据库管理员root在本地登录,要在其他客户端登录管理数据库则需要...
    99+
    2022-10-18
  • 安装phpMyAdmin来管理Mysql数据库
    在https://www.apachefriends.org/download.html下载 xampp安装包,一键安装最简单。 进行安装,默认是安装在/opt目录下。 [root@D2...
    99+
    2022-10-18
  • mycat实战(二)-mysql数据库管理
    前面介绍了基于mycat中间的mysql架构,从mysql数据库、mycat集群,haproxy(或者lvs)各个环节灭掉了单点,再加上mycat的守护进程,在高可用和负载均衡上投入到生产都没啥问题。 ...
    99+
    2022-10-18
  • Mysql数据库怎么管理日志
    Mysql数据库怎么管理日志?针对这个问题,今天小编总结这篇有关日志管理的文章,可供感兴趣的小伙伴们参考借鉴,希望对大家有所帮助 一般成熟的软件,都会有自己的日志文件。通过这些日志来快速定位问题。...
    99+
    2022-10-18
  • 如何从CLI管理MySQL数据库
    这篇文章主要为大家展示了“如何从CLI管理MySQL数据库”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何从CLI管理MySQL数据库”这篇文章吧。先决条件在...
    99+
    2022-10-18
  • MySQL数据库用户权限管理
    目录1、用户管理1.1、创建用户1.2、删除用户1.3、修改用户密码2、权限管理2.1、授予权限 grant2.2、取消权限 revoke2.3、刷新权限 flush3、密码丢失的解...
    99+
    2022-11-13
  • 【MySQL】使用DBeaver数据库管理工具进行MySQL数据库连接
    一、数据库连接信息填写 服务器地址:填写服务器部署的地址,以及端口号 2、数据库:sys 3、用户名:root 4、密码:服务器上面设置的具体密码 以上信息填写错误的报错提示:Access denie...
    99+
    2023-09-01
    数据库 mysql 服务器 db
  • MYSQL数据库管理中怎么实现权限管理
    本篇文章为大家展示了MYSQL数据库管理中怎么实现权限管理,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。 MYSQL权限简介关于mysql的权限简单的理解就是m...
    99+
    2022-10-18
  • MYSQL数据库管理之权限管理怎么配置
    这篇“MYSQL数据库管理之权限管理怎么配置”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“...
    99+
    2023-03-20
    mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作