设为首页 收藏本站
查看: 2727|回复: 0

[经验分享] MySQL数据库管理2-hj

[复制链接]

尚未签到

发表于 2018-10-7 06:25:21 | 显示全部楼层 |阅读模式
  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>  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存储引擎


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-614061-1-1.html 上篇帖子: MySQL数据管理1-hj 下篇帖子: MySQL数据库管理3-hj
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表