Mysql 02----狂神笔记
数据库操作:
结构化查询语句分类:
数据库操作:有两种方式,可以在命令行操作,也可以使用工具操作数据库。
1、使用命令行操作数据库:
创建数据库 : create database [if not exists] 数据库名;
删除数据库 : drop database [if exists] 数据库名;
查看数据库 : show databases;
使用数据库 : use 数据库名;
2、使用工具操作数据库
创建数据表:
create table [if not exists] `表名`(
'字段名1' 列类型 [属性][索引][注释],
'字段名2' 列类型 [属性][索引][注释],
#...
'字段名n' 列类型 [属性][索引][注释]
)[表类型][表字符集][注释];
数据值与列类型
列类型就是规定数据库中存该存放的数据类型
数值类型:
字符串类型:
日期与时间类型:
NULL值:理解为没有值或值未知,不要用NULL进行算数运算,结构仍未NULL。
数据字段属性
**UnSigned;**无符号的,声明该数据列不允许负数 .
ZEROFILL:0填充的,不足位数的用0来填充 , 如int(3),5则为005
Auto_InCrement:
(1)自动增长的 , 每添加一条数据 , 自动在上一个记录数上加 1(默认)
(2)通常用于设置主键 , 且为整数类型
(3)可定义起始值和步长
(4)当前表设置步长(AUTO_INCREMENT=100) : 只影响当前表
(5)SET @@auto_increment_increment=5 ; 影响所有使用自增的表(全局)
NULL 和 NOT NULL:
(1)默认为NULL , 即没有插入该列的数值
(2)如果设置为NOT NULL , 则该列必须有值
DEFAULT:默认的
-- 目标 : 创建一个school数据库
-- 创建学生表(列,字段)
-- 学号int 登录密码varchar(20) 姓名,性别varchar(2),出生日期(datatime),家庭住址,email
-- 创建表之前 , 一定要先选择数据库
CREATE TABLE IF NOT EXISTS `student` (
`id` int(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` varchar(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`pwd` varchar(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`sex` varchar(2) NOT NULL DEFAULT '男' COMMENT '性别',
`birthday` datetime DEFAULT NULL COMMENT '生日',
`address` varchar(100) DEFAULT NULL COMMENT '地址',
`email` varchar(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
-- 查看数据库的定义
SHOW CREATE DATABASE school;
-- 查看数据表的定义
SHOW CREATE TABLE student;
-- 显示表结构
DESC student; -- 设置严格检查模式(不能容错了)SET sql_mode='STRICT_TRANS_TABLES';
数据表的类型:
设置数据表的类型:
CREATE TABLE 表名(
-- 省略一些代码
-- Mysql注释
-- 1. # 单行注释
-- 2. /*...*/ 多行注释
)ENGINE = MyISAM (or InnoDB)
-- 查看mysql所支持的引擎类型 (表类型)
SHOW ENGINES;
MySQL的数据表的类型 : MyISAM , InnoDB , HEAP , BOB , CSV等…
常见的MyISAM和InnoDB类型:
狂神经验:
适用 MyISAM : 节约空间及相应速度
适用 InnoDB : 安全性 , 事务处理及多用户操作数据表
修改数据库
修改表 ( ALTER TABLE ):
修改表名 :ALTER TABLE 旧表名 RENAME AS 新表名
添加字段 : ALTER TABLE 表名 ADD字段名 列属性[属性]
删除数据表:
语法:DROP TABLE [IF EXISTS] 表名