MySQL操作数据库
2.操作数据库
操作数据库>操作数据库中的表>操作表中的数据
Mysql关键字不区分大小写
2.1操作数据库
2.1.1创建数据库
create database if not EXISTS hello
--创建数据库hello并判断是否存在数据库(如果不存在则创建)
2.1.2删除数据库
drop database if exists hello
--删除数据库hello并判断如果存在则删除数据库
2.1.3使用数据库
use hello
--选中数据库hello,对其进行操作
2.1.4查看数据库
show databases
--查看所有的数据库
DESC student --显示表的结构
2.2数据库的列类型
数值:
-tinyint 十分小的数据 1字节
-smallint 较小的数据 2字节
-int 标准的整数 4字节
-bigint 较大数据 8字节
-float 浮点数 4字节
-double 浮点数 8字节
字符串:
-char 字符串固定大小 0~255
-varchar 可变字符串 0~65535 常用的变量String
-tinytext 微型文本 2^8-1
-text 文本串 2^16-1 保存大文本
时间日期:
-date YYYY-MM-DD,日期格式
-time HH: mm: ss 时间格式
-datatime YYYY-MM-DD HH: mm: ss 最常用的时间格式
-timestamp 时间戳,较为常用
-year 年份表示
null:
-没有值,未知
-注意不要使用null进行运算,结果为null
2.3数据库字段属性(重点)
Unsigned:
-无符号的整数
-声明了该列不能声明为负数
zerofill:
-0填充的
-不足的位数,使用0来填充,int(3),5 --- 005
自增:
-通常理解为自增,自动在上一条记录上的基础上 + 1(默认)
-通常用来设计唯一的主键~index,必须是整数类型
-可以自定义设计主键自增的起始值和步长
非空:
-not null
-假设设置为not null,如果不给他赋值就会报错
-如果不填写值,默认就是null
默认:
-设置默认的值
-sex,默认值为男,如果不指定该列的值,则会有默认的值
2.4创建数据库表(重点)
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` TIMESTAMP DEFAULT null COMMENT '出生日期',
`address` VARCHAR(100) DEFAULT null COMMENT '地址',
`email` VARCHAR(50) DEFAULT null COMMENT '邮箱',
PRIMARY KEY(id)
)ENGINE=INNODB DEFAULT CHARSET=utf8
/*
目标:使用SQL语言创建一个school数据库,创建学生表(列、字段)
注意:
1、使用英文符号,表的名称和字段尽量使用``括起来
2、AUTO_INCREMENT 自增设置
3、字符串引用,用单引号括起来
4、所有的语句后面加,(英文,)最后一个语句不用加
5、PRIMARY KEY。主键;一般一个表只有一个主键
*/
格式:
create table [if not exists] `表名`(
`字段名` 列类型 [属性][索引][注释],
`字段名` 列类型 [属性][索引][注释],
`字段名` 列类型 [属性][索引][注释],
...
`字段名` 列类型 [属性][索引][注释]
)[表类型][字符集设置][注释]
2.5数据表的类型
/*
关于数据库引擎:
**InnoDB 默认使用**
*MYISAM 早些年使用**
*/
MYISAM | InnoDB | |
---|---|---|
事务支持 | 不支持 | 支持 |
数据行锁定 | 不支持 | 支持 |
外键约束 | 不支持 | 支持 |
全文索引 | 支持 | 不支持 |
表空间大小 | 较小 | 较大约2倍 |
常规使用操作:
-InnoDB:安全性高,多表多用户操作
-MYISAM:节约空间,速度较快
在物理空间存在的位置:
所有的数据库文件都存在于data目录下;本质还是文件的存储。一个文件夹对应一个数据库
MySQL引擎在物理文件上的区别
·InnoDB在数据库中只有一个 *.frm文件,以及上级目录下的ibdata1文件
·MYISAM对应文件
*.frm :表结构的定义文件
*.MYD : 数据文件(data)
*.MYI : 索引文件(index)
设置数据库表字符集编码(utf-8)
DEFAULT CHARSET=utf8
在my.ini中配置默认编码
character-set-server=utf-8
2.6修改删除表
修改
--alter table 旧表名 rename as 新表名
alter table student rename as student1 --修改表的名称(重命名为student1)
--alter table 表名 add 字段名 列属性(大小)
alter table student1 add age int(11) --增加表的字段
--alter table 表名 MODIFY 字段名 字段属性
alter table student1 MODIFY age VARCHAR(11) --修改表的字段的约束
--alter table 表名 change 旧的字段名 新字段名 字段属性
alter table student1 change age age1 int(10) --修改字段名(重命名-change)
--删除表的字段
alter table student1 drop age1
删除
--删除表,如果表存在则删除
drop table if exists student1 --drop table if exists 表名
注意点:
- `` 字段名,使用这个将字段名包裹
- 注释:--(单行注释) /**/(多行注释)
- SQL关键字大小写不敏感,建议小写
- 所有的符号全英文状态
MySQL操作数据库的更多相关文章
- PHP连接MYSQL操作数据库
PHP连接MYSQL操作数据库 <?php $con = mysql_connect("localhost","root",""); ...
- MySQL操作数据库--与MySQL零距离接触1-7
第一章 1-7操作数据库 数据库是一个集合:表 索引等. MySQL语句规范: 关键字与函数名称全部大写 数据库名称.表名称.字段名称全部小写 SQL语句必须以分号结尾 语法结构: {}: ...
- nodejs mysql 操作数据库方法二
node.js 开发指南 – Node.js 连接 MySQL 并进行数据库操作 通常在NodeJS开发中我们经常涉及到操作数据库,尤其是 MySQL ,作为应用最为广泛的开源数据库则成为我们的首选, ...
- 操作mysql操作数据库
操作数据库 查询数据库:show databases: 增加数据库:create database student default character set uft-8:(设置默认字符集) 删除数据 ...
- MySQL操作数据库和表的常用命令新手教程
1.查看数据库 获取服务器上的数据库列表通常很有用.执行show databases;命令就可以搞定. mysql> show databases; 2.创建数据库 mysql> crea ...
- python学习之老男孩python全栈第九期_数据库day001知识点总结 —— MySQL操作数据库以及数据表、基本数据类型、基本增删改查、外键定义以及创建
一. 学习SQL语句规则以及外键 1. 操作文件夹 create database db2; 创建文件夹 create database db2 default charset utf8; 创建文件夹 ...
- mysql 操作数据库创建,增删改查
创建数据库 默认字符编码 默认排序CREATE DATABASE IF NOT EXISTS day11 DEFAULT CHARSET utf8 COLLATE utf8_general_ci; / ...
- nodejs mysql 操作数据库方法一详解
nodejs mysql 数据查询例子 时间 2014-11-11 15:28:01 姜糖水原文 http://www.cnphp6.com/archives/59864 1.安装nodejs 2 ...
- MySQL操作数据库和表的基本语句(DDL)
1.创建数据库: CREATE DATABASE 数据库名; eg.CREATE DATABASE test_ddl;2.创建表 CREATE TABLE 表名(列名 数据类型 约束,...); eg ...
随机推荐
- linux crontab 定时任务 邮件问题 及其相关的 dead.letter 问题
最近开发项目的时候发现公司服务器用root账号登录的时候 一直会提示有新的信件,一直提示一直提示. 联想到另一台服务器上 的dead.letter文件每天都不断的变大 而且在 root家目录里 ,系 ...
- Nginx 从入门到放弃(五)
nginx的rewrite重写 nginx具有将一个路由经过加工变形成另外一个路由的功能,这就叫做重写. 重写中用到的指令 if (条件) {} 设定条件,再进行重写 set # 设定变量 retur ...
- Sass简单、快速上手_Sass快速入门学习笔记总结
Sass是世界上最成熟.稳定和强大的专业级css扩展语言 ,除了Sass是css的一种预处理器语言,类似的语言还有Less,Stylus等. 这篇文章关于Sass快速入门学习笔记. 资源网站大全 ht ...
- i++ & ++i不看字节码是真的难懂
package club.interview.base; /** * ++i 先"++"后赋值 * i++ 先赋值后"++" * i++ 局部变量表的值会改变, ...
- MySQL 查询 存储过程 视图 触发器 函数 索引 建表语句 数据库版本 当前登录用户 当前数据库名称
MySQL 查询 存储过程 视图 触发器 函数 索引 建表语句 数据库版本 当前登录用户 当前数据库名称 INFORMATION_SCHEMA.TABLES INFORMATION_SCHEMA. ...
- Redis四大模式之主从配置
Redis工作模式主要有单机模式.主从模式(slave).哨兵模式(sentinel).集群模式(cluster)这四种,本文主要讲解一下主从模式的部署方式. 我是windows单机进行的这套搭建操作 ...
- [POJ3977] Subet(二分枚举)
解题报告 前置知识:折半查找法(二分法) 顾名思义,折半就是把一组数据(有序)分成两半,判断我们要找的key值在哪一半当中,不断重复该操作直至找到目标key值,这玩意说白了就是二分的另一个名字. 解决 ...
- 如何排查CPU占用太高
线上项目运行时,出现问题不像在本地那么容易排查,经常需要借助日志.或者一些工具来找出问题.cpu被占满我们经常会遇到.比如我们有这样一段代码: public Class Demo1_16 { publ ...
- 前端开发-css
css: 是给html标签装饰的,变得更好看. 注释: 单行注释:/*注释内容*/ 多行注释:/* 注释内容 注释内容 注释内容 */ 通常我们在写css代码时也会用注释来划分区域(html代码多,同 ...
- @Autowired 引发的一系列思考
关于Java注解 注解定义 标记注解 - 没有元素 @interface Marker { } 单元素注解 - 只有一个元素 @interface Single { String value() de ...