数据库学习与复习笔记--数据库概念和不同类数据库CRUD操作(1)

数据库:用于存储和管理数据的仓库。

数据库的特点:

1.持久化存储数据。其实数据库就是一个文件系统

2.方便存储和管理数据

3.使用了统一的方式操作数据库。--SQL

常用数据库:MYSQL(免费、开源)、Oracle

MySQL服务启动:

cmd--> services.msc 打开服务的窗口

以管理员身份运行cmd

启动服务:net start mysql

停止服务:net stop mysql

MySQL登录和退出:

登录:mysql -uroot -proot

           mysql -hip -uroot -p链接目标密码

           mysql --host=127.0.0.1 --user=root --password=root

MySQL退出:exit或者quit

MySQL目录结构:

1.MySQL安装目录

配置文件: my.ini

2.MySQL数据目录

数据库 :文件夹

表:文件

数据:文件中存储的数据

什么是SQL?

Structured Query Language:结构化查询语言

其实就是定义了操作所以关系型数据库的规则。每一种数据库操作的方式存在不一样的地方,称为“方言”。

SQL通用语法:

1.SQL语句可以单行或者多行书写,以分号结尾。

2.可以使用空格和缩进提高程序的可读性。

3.MySQL数据库的SQL语句不区分大小写,关键字建议使用大写

4.三种注释 

单行注释: -- 注释内容 或者 # 注释内容(MySQL特有)

多行注释:/* 注释 */

SQL分类:

DDL:Data Difinition Language 数据定义语言,一般用来库和表头的创建和删除;

DML:Data Manipulation Language 数据操作语言,一般用来做表中数据的增加、删除和修改;

DQL:Data Query Language 数据查询语言,用来在数据库中查询的语言,select就在这里;

DCL:Data Control Language 数据控制语言,一般是DBA才会用到的数据库用户管理及日常维护语言。

DDL:操作数据库和表

1.操作数据库:CRUD 

C(Create):创建

创建数据库:

   create database 数据库名称;

创建数据库,判断不存在:

   create database if not exists  数据库名称;

创建数据库,并指定字符集:

   create database 数据库名称 character set 字符集名称;

练习:创建一个db4数据库,判断是否存在,并指定字符集为gbk:

   create database if not exists db4 character set gbk;

R(Retrieve):查询

查询所有数据库的名称:show databases;

查看某个数据库的字符集(查询某个数据库的创建语句):show create database 数据库名称;

U(Update):修改

修改数据库的字符集

   alter database 数据库名称 character set 字符集名称;

D(Delete):删除

删除数据库

   drop database 数据库名称;

判断数据库存在,存在再删除

   drop database if exists 数据库名称;

使用数据库:

查询当前正在使用的数据库名称: select database();

使用数据库:use  数据库名称;

2.DDL操作表

C(Create):创建

语法:

create table 表名(

    列名1 数据类型1,

    列名2 数据类型2,

    ...

    列名n 数据类型n

);

注意最后一列不需要加逗号(,)

数据库类型:

int :整数类型 如 age int,

double:小数类型 如 score double(5,2), 长度最大为5,精度为2

date:日期类型,只包含年月日的日期,格式yyyy-MM-dd

datetime:日期,包含年月日时分秒 yyyy-MM-dd  HH:mm-ss

timestamp:时间戳类型,包含年月日时分秒 yyyy-MM-dd  HH:mm-ss

和datetime区别:如果将来不给这个字段赋值,或者赋值为null,则默认使用当前系统时间赋值。

varchar:字符串 name varchar(20):姓名最大20个字符

创建表

create table student(

          id int,

          name varchar(32),

          age int,

          score double(4,1),

          birthday date,

          insert_time timestamp

);

复制表:create table 表名 like 被复制的表名;

R(Retrieve):查询

查询某个数据库中所有表名称:show tables;

查询表结构:desc 表名;

show tables;

U(Update):修改

修改表名:   alter table  表名  rename to 新的表名;

修改表的字符集: alter table 表名 character set 字符集名称;

添加一列:alter table 表名 add 列名 数据类型;

修改列的名称   类型:  

alter table 表名 change 列名 修改后的新列名 新数据类型;

alter table 表名 modify 列名 新数据类型; 

删除列: alter table 表名 drop 列名;

D(Delete):删除

drop table 表名;

drop table if exists 表名;

客户端图形化工具:SQLYog

SQLyog-12.0.9-0.x64 下载地址

链接:https://pan.baidu.com/s/1WI70PwRQCyqPWI4OvSIBrw 
提取码:g6gm 
内含激活码,自行激活注册。

DML:增删改表中数据

1.添加数据:

语法:insert into 表名(列名1,列名2,...列名n) values(值1,值2,  ...值n); 

注意:列名和值要一一对应

如果表名后,不定义列名,则默认给所有列添加值。

insert into 表名 values(值1,值2,  ...值n); 

除了数字类型,其他类型需要用引号(单双引号都可以)引起来。

2.删除数据

delete from 表名  [where  条件];

注意:如果不加条件,则删除表中所有记录。

如果要删除所有记录

delete from 表名; -- 不推荐使用。有多少条记录就会执行多少次删除操作。

TRUNCATE TABLE 表名;  -- 先删除表,然后再创建一个一模一样的空表。效率更高,推荐使用。

3.修改数据:

语法:update 表名 set 列名1=值1,列名2=值2,......[where 条件];

注意:如果不加任何条件,则会将表中记录全部进行修改。

DQL:查询表中的记录

select * from 表名;

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值