MySQL

1.     MySQL安装与配置

2.     数据库概念

2.1. 数据库服务器、数据库和表之间的关系

所谓安装数据库服务器, 只是在机器上安装了一个数据库管理程序, 这个管理程序可以管理多个数据库.

一般开发人员在设计项目的时候会针对每一个应用创建一个数据库.

为了保存每一类实体, 在一个数据库中创建多个表.

2.2. 数据在数据库中的存储方式

id=1              id=2

name=Tom      name=Jerry

age=18        age=20

 

列(column)         列(column)       列(column)

 
 

id

 
 
 

name

 
 
 

      age

 
 
 

      1

 
 
 

     Tom

 
 
 

      18

 
 
 

      2

 
 
 

     Jerry

 
 
 

      20

 
 
 

 

 
 
 

 

 
 
 

 

 

 

行(row)

行(row)

 

 

每一行(一条记录)对应Java中的一个对象

每一列对应对象的一个属性

操作库

创建库

CREATE DATABASE [IF NOT EXISTS] 数据库名 [参数[ 参数] [ 参数]...];

参数:

    CHARACTER SET 码表名

    COLLATE 校对规则名   参见帮助文档第10章

命令:show character set;可以显示MySQL支持的字符集和校对规则

 

Showcollation like ‘latin1%’;   显示latin1字符集可以采用的校对规则

 

显示库

    SHOW DATABASES;

显示数据库创建语句

    SHOW CREATE DATABASE 数据库名; 查看数据库所采用的字符集

修改库

    ALTER DATABASE 数据库名[ 参数[ 参数][ 参数]...];

    注意: 不能改数据库的名字

删除库

    DROP DATABASE [IF EXISTS] 数据库名;

练习:

    创建一个数据库db1

创建一个数据库db2指定字符编码, 校对规则

显示所有数据库

显示db2的字符编码

将db2的字符编码设置为gbk

删除db2数据库

3.     操作表

操作表之前使用需要先确定使用哪个数据库

    USE 数据库名

创建表

CREATE TABLE 表名(列名 类型[,列名 类型][,列名 类型]...);

 

查看所有表

    SHOW TABLES;

查看表的创建语句

    SHOW CREATE TABLE 表名;

显示表结构

    DESC 表名;

修改表名

    RENAME TABLE 原表名 TO 新表名;

修改字符集

    ALTER TABLE 表名 CHARACTER SET 字符集名;

删除表

    DROP TABLE 表名;

练习

    创建表employee, 包含以下字段:

id            整型             主键, 自动生成

name          字符              非空

gender        字符或bit        非空

birthday          日期             

entry_date    日期              非空

position          字符             

salary        小数             

resume        大文本

将表名改为user

显示表结构

4.     操作列

追加列

  ALTER TABLE 表名 ADD 列名 类型[,列名 类型][,列名类型]...;

修改列类型

    ALTER TABLE 表名 MODIFY 列名 类型[,列名类型][,列名 类型]...;

修改列

    ALTER TABLE 表名 CHANGE COLUMN 原列名 新列名 类型;

删除列

    ALTER TABLE 表名 DROP 列名;

练习

    添加一列用来存储照片

将name长度修改为30

将name改名为username

删除photo列

 

 

Insertinto

Update

delete

select

5.     操作数据(增删改)

5.1. 插入

语法:

    INSERT INTO 表名[(列名[,列名]...)] VALUES(值[,值]...);

注意事项:

    插入值类型必须与对应列的数据类型一致

    数据不能超出长度

    插入值得为之必须与列名顺序一致

    字符和日期数据要放在单引号中

    插入空值使用null

    如果不指定插入哪一列, 就是插入所有列

中文数据

    由于默认码表是utf8, 而cmd.exe的码表是gbk, 在插入中文数据的时候会报错, 所以我们需要修改客户端码表

    先查看系统变量: SHOW VARIABLES LIKE 'character%';

    修改客户端码表: SET character_set_client=gbk;

    这样就解决了中文插入的问题, 但在查询数据的时候仍然显示为乱码, 这是因为mysql向cmd传输数据的时候使用的是utf8

    修改输出数据的码表: SET character_set_results=gbk;

练习

    向user表中插入3条包含中文的数据

insertinto user(id,username,gender,birthday,position,salary,resume)

values(1,'张三','男','1990-9-9','程序员',6000,'介绍');

 

insertinto user(id,username,gender,birthday,position,salary,resume)

values(2,'李四','男','1990-9-9','程序员',6000,'介绍');

 

insertinto user(id,username,gender,birthday,position,salary,resume)

values(3,'王五','男','1990-9-9','测试',6000,'介绍');

 

insertinto user(id,username,gender,birthday,position,salary,resume)

values(4,'赵六','男','1990-9-9','美工 ',6000,'介绍');

 

5.2. 修改

语法

    UPDATE 表名 SET 列名=值[,列名=值]...[WHERE 条件语句];

注意事项

    WHERE子句选择满足条件的行进行更新, 如果不写, 则更新所有行

练习

    将所有员工的薪水改为5000

    将姓名为张三的员工薪水改为7000

    给李四加薪3000, 并且职位改为经理

5.3. 删除

语法

    DELETE FROM 表名 [where 条件语句]

注意事项

    如果不加where子句, 将删除表中所有记录

    delete只能用作删除行, 不能删除某一列的值, 需要用update

    在delete和update的时候需要注意表与表之间的关联关系

    删除表中所有数据可以使用: TRANCATE 表名, 这种方式会删除旧表重新创建, 在数据较多的时候使用

练习

    删除所有美工

    删除表中所有数据

6.     备份恢复数据库

备份数据库

    输入quit退出mysql, 在cmd.exe中输入:

mysqldump –u用户名 –p密码 数据库名 > 文件名

恢复数据库

    进入mysql.exe之后, 使用数据库之后

    source 文件名

练习:

       备份指定数据库, 删除数据库, 恢复

操作数据(查询)

DISTINCT

语法

    SELECT [DISTINCT] 列名[, 列名]... FROM 表名

注意事项

    *可以替代列名, 表示所有列, 但是通常我们为了提高代码的可读性, 不使用*

    DISTINCT为过滤重复记录

    如果DISTINCT后面跟多列, 是过滤掉多列合并之后的重复

练习

    查询employee表中所有记录

selectid,username,gender,birthday,position,salary,resume from user;

    查询employee表中所有人的薪水

selectusername,salary from user;

    查询employee表中包含哪些岗位

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值