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]