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操作数据库的更多相关文章

  1. PHP连接MYSQL操作数据库

    PHP连接MYSQL操作数据库 <?php $con = mysql_connect("localhost","root",""); ...

  2. MySQL操作数据库--与MySQL零距离接触1-7

    第一章 1-7操作数据库 数据库是一个集合:表 索引等. MySQL语句规范: 关键字与函数名称全部大写 数据库名称.表名称.字段名称全部小写 SQL语句必须以分号结尾 语法结构:       {}: ...

  3. nodejs mysql 操作数据库方法二

    node.js 开发指南 – Node.js 连接 MySQL 并进行数据库操作 通常在NodeJS开发中我们经常涉及到操作数据库,尤其是 MySQL ,作为应用最为广泛的开源数据库则成为我们的首选, ...

  4. 操作mysql操作数据库

    操作数据库 查询数据库:show databases: 增加数据库:create database student default character set uft-8:(设置默认字符集) 删除数据 ...

  5. MySQL操作数据库和表的常用命令新手教程

    1.查看数据库 获取服务器上的数据库列表通常很有用.执行show databases;命令就可以搞定. mysql> show databases; 2.创建数据库 mysql> crea ...

  6. python学习之老男孩python全栈第九期_数据库day001知识点总结 —— MySQL操作数据库以及数据表、基本数据类型、基本增删改查、外键定义以及创建

    一. 学习SQL语句规则以及外键 1. 操作文件夹 create database db2; 创建文件夹 create database db2 default charset utf8; 创建文件夹 ...

  7. mysql 操作数据库创建,增删改查

    创建数据库 默认字符编码 默认排序CREATE DATABASE IF NOT EXISTS day11 DEFAULT CHARSET utf8 COLLATE utf8_general_ci; / ...

  8. nodejs mysql 操作数据库方法一详解

    nodejs mysql 数据查询例子 时间 2014-11-11 15:28:01  姜糖水原文  http://www.cnphp6.com/archives/59864 1.安装nodejs 2 ...

  9. MySQL操作数据库和表的基本语句(DDL)

    1.创建数据库: CREATE DATABASE 数据库名; eg.CREATE DATABASE test_ddl;2.创建表 CREATE TABLE 表名(列名 数据类型 约束,...); eg ...

随机推荐

  1. Vue组件篇——Vue3.0中使用高德地图

    VUE-CLI 3.0 中配置高德地图 在项目开发中,地图组件 1.首先,需要注册高德开放平台的账号,并在[应用管理]页面[创建新应用],为应用添加Key值 高德开放平台:https://lbs.am ...

  2. 一不小心,我就上传了 279674 字的 MySQL 学习资料到 github 上了

    自从2019年11月我们出版了<千金良方--MySQL 性能优化金字塔法则>一书之后,持续不断有人来询问我MySQL 4 个系统字典库相关的问题,因为篇幅原因,书中并没有完整收录4个字典库 ...

  3. CountDownLatch 计数器

    这里我暂时只讲CountDownLatch的作用和怎么使用,至于他是怎么实现这种功能的,涉及源码,以后我再补上. 正文 什么是CountDownLatch? CountDownLatch是在java1 ...

  4. 关于 urlencode 的使用和 json 模块的介绍

    先附上一段 “百度翻译” 的爬虫代码 # python爬虫实现百度翻译 # urllib和request POST参数提交 from urllib import request,parse impor ...

  5. vue全家桶(2.4)

    3.6.重定向和别名 3.6.1.重定向 路由重定向通俗的说就是从一个路由重新定位跳转到另一个路由,例如:访问的 "/a" 重定向到"/b" 重定向也是通过配置 ...

  6. MFC 添加C++类,别的类不通过C++类的定义的对象就可以直接调用C++类里面的成员函数;

    MFC 添加C++类,不用定义C++类的对象,别的类不通过C++类的定义的对象就可以直接调用C++类里面的成员函数: 1先在mfc程序中添加普通类CProdata,然后删除头文件Prodata.h里面 ...

  7. 实现MFC扩展DLL中导出类和对话框

    如果要编写模块化的软件,就要对对动态链接库(DLL)有一定的了解,本人这段时间在修改以前的软件时,决定把重复用的类和对话框做到DLL中,下面就从一个简单的例子讲起,如何实现MFC扩展DLL中导出类和对 ...

  8. Spring Cloud Alibaba基础教程:Nacos 生产级版本 0.8.0

    昨晚Nacos社区发布了第一个生产级版本:0.8.0.由于该版本除了Bug修复之外,还提供了几个生产管理非常重要的特性,所以觉得还是有必要写一篇讲讲这次升级,在后续的文章中也都将以0.8.0版本为基础 ...

  9. 错误记录-MySql.Data.MySqlClient.MySqlException (0x80004005): Timeout expired.

    -- ::25.026 +: [ERR] Connection id "0HLQH64H76UL5", Request id "0HLQH64H76UL5:0000000 ...

  10. SpringCloud之OpenFeign

    SpringCloud之openFeign Spring Cloud的子项目之一,Spring Cloud OpenFeign以将OpenFeign集成到Spring Boot应用中的方式,为微服务架 ...