wind-cold 发表于 2018-10-5 14:11:01

mysql 数据库的基本操作1-Erstickt的博客

  mysql数据库管理 day01
  相关概念问题
  数据库介绍? 存储数据的仓库
  数据库服务都那些公司在使用?
  购物网站    游戏网站      金融网站
  数据服务存储的是什么数据?
  帐号信息   对应的数据信息
  提供数据库服务的软件有那些?
  开源软件mysql 、mongodb、redis
  商业软件oracle 、 db2、 SQLSERVER
  软件是否跨平台? Linux    Unix   Windows
  软件包的来源: 官网下载      使用操作系统安装光盘自带软件包
  mysql软件介绍?    mysql   mariadb
  关系型数据型软件: 要按照一定组织结构存储数据,并且数据和数据之间可以互相关联操作。
  跨平台 Linux    Unix   Windows
  可移植性强
  支持多种语言Python/Java/Perl/PHP
  生产环境中,数据服务和网站服务一起使用 构建网站运行平台
  LNMP    LAMP   WNMP    WAMP
  mysql软件包的封包类型: rpm包   源码包   可以自定义安装信息
  非关系型数据库软件(NoSQL)mongodb、
  redis 、 memcached
  1搭建mysql数据库服务器
  2mysql服务基本使用
  3 mysql数据类型
  一、搭建mysql数据库服务器 192.168.4.51
  装包
  修改配置文件
  启动服务
  查看服务进程和端口号
  服务名mysqld
  服务的主配置文件/etc/my.cnf
  数据目录/var/lib/mysql
  日志文件   /var/log/mysqld.log
  二、数据库服务的基本使用
  2.1 使用初始密码在本机连接数据库服务
  mysql   [-h数据库服务器ip地址   -u用户名    -p'密码'

  2.2 重置本机连接密码 mysql>>
  root@"localhost" >  2.3 把数据存储到数据库服务器上的过程?
  2.4 sql命令分类? DDL   DML    DTL    DCL
  2.5 sql命令使用规则?
  2.6 管理数据库的sql命令 及 库名的命名规则
  2.7 管理表的 sql命令
  建表的语法格式?
  create   table库名.表名(
  字段名   类型(宽度)约束条件,
  字段名   类型(宽度)约束条件,
  .....
  );
  2.8管理记录的sql命令
  查看
  插入
  更新
  删除
  +++++++++++++++++++++++++
  三、mysql数据类型
  3.1数值类型   (成绩年龄   工资)
  每种类型的存储数据的范围都是固定
  整数类型 (只能存储整数)
  微小整型    小整型         中整型                   大整型    极大整型
  tinyint      smallint      MEDIUMINT      INT      bigint
  *****unsigned    使用数值类型有符号的范围。
  浮点型 (存储小数)
  float(M,N)
  double(M,N)
  M设置总位数
  N   设置小数位位数
  正数.小数          总位数   整数位    小数位
  18088.88            7         5             2
  3.2字符类型   (商品名称   籍贯   姓名   生产厂家)
  char(255)   固定长度字符类型
  varchar (65532)   变长字符类型
  大文本类型 (音频文件 视频文件图片文件)
  blob
  text
  3.3 日期时间类型
  (注册时间    约会时间   开会时间   入职时间   生日)
  年       year   YYYY               2018
  日期   date   YYYYMMDD   20180423
  时间   time   HHMMSS          161958
  日期时间 datetime/timestamp
  YYYYMMDDHHMMSS   20180423161958
  获取日期时间给对应的日期时间类型的字段赋值
  获取日期时间函数
  now() 获取当期系统的时间
  year(日期时间)获取指定时间中的年
  month(日期时间)获取指定时间中的月
  date(日期时间)获取指定时间中的日期
  day(日期时间)获取指定时间中的号(天)
  time(日期时间)获取指定时间中的时间
  可以使用2位数字给year类型的字段赋值,规律如下:
  01-69   20XX
  70-99   19XX
  3.4 枚举类型(插入记录 时 记录的值 在列举的范围内选择)
  性别    爱好    专业
  enum(值列表)       单选
  set(值列表)            多选
  数据类型的关键字   存储范围赋值方式合理使用数据类型
  **划重点
  数值类型的宽度 是显示宽度,不能够给字段赋值的大小。字段的值由类型决
  定。
  mysql-day02
  一 、字段约束条件
  1.1作用: 限制如何给字段赋值的
  1.2包括内容有:NULL    Key    Default   Extra
  NULL是否允许给字段赋null值
  null         默认允许赋null值
  notnull   不允许赋null值
  key   键值类型:普通索引   唯一索引全文索引主键外 键
  Default 默认值 作用:当不被字段赋值时,使用默认值给字段赋值
  不设置默认值是系统定义的是null
  default   值
  Extra    额外设置,字段是否设置为自动增加,默认没有自动增长功能
  二、修改表结构
  2.1 修改表结构的命令

  mysql> >  添加新字段      add   字段名    类型(宽度)[ 约束条件]
  删除已有字段drop   字段名
  修改已有字段的类型宽度及约束条件
  *划重点**修改时不能与已经存储的数据矛盾的话不允许修改
  modify   字段名    类型(宽度)[ 约束条件]
  修改字段名
  change   源字段名   新字段名   类型(宽度)[ 约束条件]
  修改表名
  altertable源表名rename      新表名;
  三、mysql键值
  设置在表中字段上的,作用是约束如何给字段赋值。同时会给字段做索引。
  索引介绍: 树状目录结构类似与书的“目录”
  优点:加快查询表记录的速度
  缺点 : 会减慢编辑表记录的速度,且占用磁盘的物理存储空间
  (deleteinsert   update)
  字典总页面数1000页
  目录信息
  1------100页   记录目录信息
  101---1000页   正文
  查字典的方法
  笔画
  部首
  拼音
  修正内容时,修改内容 添加内容删除内容
  stuinfo   /var/lib/mysql/db2/stuinfo.*

  name   age   home>  DBA
  3.1 键值:普通索引   唯一索引全文索引主键外 键
  3.1.1普通索引的使用(index)
  使用规则?
  查看
  desc表名;
  show   indexfrom   表名;
  Table: t2
  Key_name: aaa
  Column_name: age
  Index_type: BTREE(二叉树)
  创建
  在已有表创建
  create   index   索引名on   表名(字段名);
  建表是时创建
  createtable表名(
  字段列表,
  index(字段名),
  index(字段名),
  );
  删除
  drop   index   索引名on   表名;
  +++++++++++++++++++++++++++++++
  3.1.2主键 primary   key
  (普通主键    复合主键    主键+auto_increment)
  使用规则?
  查看   desc   表;key ----> PRI
  创建

  在已有表创建    >  建表时创建
  createtable表名(
  字段列表,
  primarykey(字段名)
  );
  创建复合主键的使用:多个字段一起做主键,插入记录时,只要做主键字段的值不同时重复,就可以插入记录。(必须一起创建一起删除,多个字段的值不允许同时相同)
  descmysql.db;
  descmysql.user;
  主键primarykey通常和auto_increment连用。
  让字段的值自动增长i++
  数值类型               i=i+1

  删除主键   mysql> >  ++++++++++++++++++++++++++++++++++++++
  3.1.3外 键(作用 限制如何给字段赋值的)
  给当前表中字段赋值时,值只能在指定(其他)表的指定字段值的范围里选择。
  使用规则?
  创建外键 foreignkey 的命令格式:
  create   table   表(
  字段名列表,
  foreignkey(字段名)   references表名(字段名)
  onupdate cascade    ondeletecascade
  )engine=innodb;
  缴费表
  use studb;
  createtablejfb(
  jfb_id    int(2)   zerofillprimary keyauto_increment,
  name   char(15),
  pay   float(7,2)
  )engine=innodb;
  insert intojfb (name,pay)values("bob",26800);
  insert intojfb (name,pay)values("tom",26000);
  select*fromjfb;
  班级表
  createtablebjb(
  bjb_id   int(2) zerofill,
  name   char(15),
  foreignkey(bjb_id)   referencesjfb(jfb_id)
  onupdate cascade    ondeletecascade
  )engine=innodb;
  insertinto   bjb values(3,"lucy");
  insertinto   bjb values(1,"bzengjiaob");
  insertinto   bjb values(2,"tom");
  select* from bjb;
  mysql> updatejfb set jfb_id=9 where name="bob";
  mysql> delete from jfb where jfb_id=2;
  select from jfb;
  select   from bjb;
  查看mysql> show create table 表名;
  删除外键
  altertable表名dropforeign key外键名;
  altertablebjbdropforeign keybjb_ibfk_1;
  mysql> delete from jfb where jfb_id=02;他有同步的作用 班级表也没有这一条
  mysql> update jfb set name="xixi"where jfb_id=05;修改缴费表ID是05 把他的名字改成xixi
  在已有表创建
  mysql> delete from bjb;

  mysql>>  (jfb_id)onupdate cascade    ondeletecascade;

页: [1]
查看完整版本: mysql 数据库的基本操作1-Erstickt的博客