一、数据库基础

    • 表 table:数据是保存在表内,保存在一个表内的数据,应该具有相同的数据格式
    • 行:行用于记录数据
    • 记录:行内的数据
    • 列:列用于规定数据格式
    • 字段:数据的某个列
    • 主键:唯一地标识表中的某一条记录,不能空,不能重复

二、数据库的数据类型

1、数字类型

整数: tinyint、smallint、mediumint、int、bigint
浮点数: float、double、real、decimal
日期和时间: date、time、datetime、timestamp、year

2、字符串类型

字符串: char、varchar
文本: tinytext、text、mediumtext、longtext

3、二进制

  (可用来存储图片、音乐等): tinyblob、blob、mediumblob、longblob

4、列的约束:

  

三、数据库连接

  在关于数据库的第一篇文章中就给大家讲了使用Navicat连接数据库的方法,那么这里再给大家讲解一下使用命令连接数据库的方式。

  一般在公司开发中,可能会将数据库统一搭建在一台服务器上,所有开发人员共用一个数据库,而不是在自己的电脑中配置一个数据库,远程连接命令

mysql -h ip地址 -u root -p
  • -h后面写要连接的主机ip地址
  • -u后面写连接的用户名
  • -p回车后写密码

四、数据库操作

1、创建数据库

create database 数据库名 charset=utf8;

2、删除数据库

drop database 数据库名;

3、切换数据库

use 数据库名;

4、查看当前选择的数据库

select database();

5、查看目前所有的数据库

show databases;

五、表操作

1、查看当前数据库中所有表

show tables; 

2、创建表

create table 表名(列及类型);
  • 列名:id
  • 类型:int unsigned
  • 约束1:not null
  • 约束2:primary key
  • 约束3:auto_increment

  列的格式:列的名称 类型 约束

例如:

create table hero(h_id int auto_increment primary key,h_name varchar() not null);

3、修改表

语法:

alter table 表名 add(添加)|modify(修改)|drop(删除) 列名 类型;

添加列:h_skill 为字符类型

alter table hero add h_skill varchar();

修改列:h_skill修改本属性不能为空

alter table hero modify h_skill varchar() not null;

4、删除表

drop table 表名;

5、查看表结构

desc 表名;

例如:

mysql> desc hero;
+---------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+----------------+
| h_id | int() | NO | PRI | NULL | auto_increment |
| h_name | varchar() | NO | | NULL | |
| h_skill | varchar() | NO | | NULL | |
+---------+-------------+------+-----+---------+----------------+
rows in set (0.00 sec)

6、更改表名称

rename table 原表名 to 新表名;

7、查看边的创建语句

show create table 表名

例如:

mysql> show create table hero;
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| hero | CREATE TABLE `hero` (
`h_id` int() NOT NULL AUTO_INCREMENT,
`h_name` varchar() NOT NULL,
`h_skill` varchar() NOT NULL,
PRIMARY KEY (`h_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
|
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
row in set (0.00 sec)

六、数据操作

1、增加数据

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

例如:

insert into hero(h_id,h_name,h_skill) values(,'韩信','裂天爆斩');

  主键列是自动增长,但是在全列插入时需要占位,通常使用0,插入成功后以实际数据为准

2、简单查询数据

select * from 表名

例如:

mysql> select * from hero;
+------+--------+--------------+
| h_id | h_name | h_skill |
+------+--------+--------------+
| | 韩信 | 裂天爆斩 |
+------+--------+--------------+
row in set (0.00 sec)

3、修改数据

update 表名 set 列1=值1,... where 条件

例如:

update hero set h_skill='真裂天爆斩' where h_id=;
mysql> select * from hero;
+------+--------+-----------------+
| h_id | h_name | h_skill |
+------+--------+-----------------+
| | 韩信 | 真裂天爆斩 |
+------+--------+-----------------+
row in set (0.00 sec)

4、物理删除数据

delete from 表名 where 条件

例如:

mysql> delete from hero where h_id=;
Query OK, row affected (0.01 sec) mysql> select * from hero;
Empty set (0.00 sec)

5、逻辑删除,

  本质就是修改操作update ,并没有删除,只有用isdelete去和其他没有删除的数据区别,所以叫做逻辑删除,方便回复误删数据

alter table hero add isdelete bit default ;
在需要做逻辑删除的时候写上
update hero set isdelete= where h_id=;

最新文章

  1. Python中获取异常(Exception)信息
  2. SmartUpload实现文件上传时file和表单文本同时提交的问题
  3. 主从Reactor多线程模型
  4. HTML5之 Microdata微数据
  5. java小算法—大衍数列
  6. ural 1090 In the Army Now
  7. thinkphp微信开发:安全模式消息加解密
  8. 寻找失踪的整数数组(Find the missing integer)
  9. 使用pycurl探测web服务质量
  10. BZOJ 4539: [Hnoi2016]树 [主席树 lca]
  11. 超链接a标签的属性target的可选值有哪些以及区别
  12. 新手立体四子棋AI教程(3)——极值搜索与Alpha-Beta剪枝
  13. 一、Redis-NoSQL数据库
  14. EM算法(坐标上升算法)
  15. Lock和Condition在JDK中LinkedBlockingQueue的应用
  16. xadmin系列之django的url分发的方式
  17. php sqlserver及xdebug扩展配置
  18. nginx在centos & ubuntu上的安装
  19. oracle12c创建用户指定表空间
  20. HTTPS为什么又快又安全?

热门文章

  1. x:Static
  2. 搜索服务器Elasticsearch
  3. UWP 裁切 SoftwareBitmap
  4. siliverlight某些事件无法响应
  5. XE Delphi 判断字符为中文的方法
  6. swift 如何控制view的显示与隐藏
  7. Win10《芒果TV》更新v3.4.10春光版:优化弹窗体验,修复热键和推送
  8. JavaScript生成树形菜单(递归算法)
  9. winform子容器随父容器的变化设置
  10. 从Qt5开始只剩下setCodecForLocale这一个了,只是影响Qt对toLocal8Bit相关函数的编码方式(在源码里写非英文,官方推荐“\xE4\xBD...”这种)good