数据库介绍

数据库(database,DB)是指长期存储在计算机内的,有组织,可共享的数据的集合。数据库中的数据按一定的数学模型组织、描述和存储,具有较小的冗余,较高的数据独立性和易扩展性,并可为各种用户共享。

关系数据库: MySql ,Oracle, sql server , db2 ,sqlite,

非关系数据库: redis mongodb

so无所谓。。。

MySQL数据库

安装

windows上安装略

linux上安装略

启动

端口号3306

设置密码

 mysqladmin -uroot password ''   #设置初始密码,初始密码为空因此-p选项没有用
mysqladmin -u root -p123 password '' #修改root用户密码

登录数据库

 mysql               #本地登录,默认用户root,空密码,用户为root@127.0.0.1
mysql -uroot -p1234 #本地登录,指定用户名和密码,用户为root@127.0.0.1
mysql -uroot -p1234 -h 192.168.31.95 #远程登录,用户为root@192.168.31.95

忘记密码1:从删库到跑路

忘记密码2:越过授权库

SQL语句

SQL语句:结构化语句,SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。几乎所有的关系型数据库都有对SQL语句的支持

SQL语句规范:
1、不区分大小写(命令建议大写,原因在于,在SQL解析的过程中,数据库会自动将小写的命令转换成大写,当有大批量SQL语句操作的时候,转换也会产生一定的开销)
2、以分号作为结束符号
3、注释(单行--,多行/* */)

SQL语句操作对象:数据库的操作、数据表的操作、表记录的操作

数据库的操作
1、查看所有的数据库

mysql> SHOW DATABASES;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sakila |
| sys |
| world |
+--------------------+
6 rows in set (0.00 sec)

2、创建数据库(即在磁盘上创建一个对应的文件夹)

语法:create  database  [if not exists]  db_name  [character set xxx];

   命令      可选判断    数据库名   数据库的字符编码

mysql> CREATE DATABASE IF NOT EXISTS student CHARACTER SET utf8;
Query OK, 1 row affected (0.01 sec) mysql> SHOW DATABASES;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sakila |
| student |
| sys |
| world |
+--------------------+
7 rows in set (0.00 sec)

3、查询一个数据库的创建方式(创建命令)

语法:show  create  database  db_name ;

   命令          数据库名

mysql> SHOW CREATE DATABASE student;
+----------+------------------------------------------------------------------+
| Database | Create Database |
+----------+------------------------------------------------------------------+
| student | CREATE DATABASE `student` /*!40100 DEFAULT CHARACTER SET utf8 */ |
+----------+------------------------------------------------------------------+
1 row in set (0.04 sec)

4、修改数据库字符编码

语法:alter  database  db_name  character set gbk;

     命令         数据库名    修改字符编码

mysql> ALTER DATABASE student CHARACTER SET gbk;
Query OK, 1 row affected (0.01 sec) mysql> SHOW CREATE DATABASE student;
+----------+-----------------------------------------------------------------+
| Database | Create Database |
+----------+-----------------------------------------------------------------+
| student | CREATE DATABASE `student` /*!40100 DEFAULT CHARACTER SET gbk */ |
+----------+-----------------------------------------------------------------+
1 row in set (0.00 sec) #注:修改数据库名字,直接找到该数据库文件夹,修改文件夹名字

5、删除数据库

mysql> DROP DATABASE student;
Query OK, 0 rows affected (0.00 sec) mysql> SHOW DATABASES;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sakila |
| sys |
| world |
+--------------------+
6 rows in set (0.00 sec)

6、使用数据库(即切换数据库,进入到数据库内)

mysql> USE mysql;
Database changed
mysql> SELECT database();
+------------+
| database() |
+------------+
| mysql |
+------------+
1 row in set (0.00 sec)

-- 注意:进入到某个数据库后没办法再退回之前状态,但可以通过use进行切换

查看当前使用的数据库 select database();

数据表的操作

表内的列:字段

表内的行:表记录

1、创建一个表(进入库里):最后一个字段不加逗号结束

语法:create  table  table_name(

      字段名 字段数据类型 [约束] ,
      字段名 字段数据类型 [约束] ,
      字段名 字段数据类型 [约束] ,
      ....
      字段名 字段数据类型 [约束] )  [character set xxx];

约束: (not null + unique就等于主键),约束不止这三个
  主键(primary key):非空 且 唯一
  not null: 非空约束
  unique: 唯一约束

mysql> CREATE DATABASE teachers;
Query OK, 1 row affected (0.00 sec) mysql> USE teachers;
Database changed mysql> CREATE TABLE teacher1(
-> id INT primary key,
-> name VARCHAR(20) not null,
-> age INT,
-> birth DATE);
Query OK, 0 rows affected (0.51 sec)

2、查看数据库的表

mysql> SHOW TABLES;
+--------------------+
| Tables_in_teachers |
+--------------------+
| teacher1 |
+--------------------+
1 row in set (0.00 sec)

3、查看表结构

mysql> DESC teacher1;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id | int(11) | NO | PRI | NULL | |
| name | varchar(20) | NO | | NULL | |
| age | int(11) | YES | | NULL | |
| birth | date | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

4、查看创建表命令

mysql> SHOW CREATE TABLE teacher1;
+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| teacher1 | CREATE TABLE `teacher1` (
`id` int(11) NOT NULL,
`name` varchar(20) NOT NULL,
`age` int(11) DEFAULT NULL,
`birth` date DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

5、增加列(字段):可以增加多个列,类似于表创建的格式。

语法:alter  table  tab_name  add  [column]  列名  类型 [完整性约束条件] [first|after 字段名];

     命令       表名    添加     列                   定义列位置,first最前边,after在某个字段之后

mysql> ALTER TABLE teacher1 ADD COLUMN sex INT;
Query OK, 0 rows affected (0.58 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC teacher1;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id | int(11) | NO | PRI | NULL | |
| name | varchar(20) | NO | | NULL | |
| age | int(11) | YES | | NULL | |
| birth | date | YES | | NULL | |
| sex | int(11) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+

注:COLUMN可以省略

mysql>  ALTER TABLE teacher1 ADD addr VARCHAR(20) first;
Query OK, 0 rows affected (0.53 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC teacher1;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| addr | varchar(20) | YES | | NULL | |
| id | int(11) | NO | PRI | NULL | |
| name | varchar(20) | NO | | NULL | |
| age | int(11) | YES | | NULL | |
| birth | date | YES | | NULL | |
| sex | int(11) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
6 rows in set (0.00 sec)

6、修改一列类型

语法:alter  table  tab_name  modify  列名  类型  [完整性约束条件] [first|after 字段名];

mysql>  ALTER TABLE teacher1 MODIFY sex CHAR AFTER id;
Query OK, 0 rows affected (0.82 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC teacher1;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| addr | varchar(20) | YES | | NULL | |
| id | int(11) | NO | PRI | NULL | |
| sex | char(1) | YES | | NULL | |
| name | varchar(20) | NO | | NULL | |
| age | int(11) | YES | | NULL | |
| birth | date | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
6 rows in set (0.00 sec)

7、修改列名

语法:alter  table  tab_name  change  [column]  列名  新列名  类型  [完整性约束条件] [first|after 字段名];

mysql>  ALTER TABLE teacher1 CHANGE birth birthday DATE;
Query OK, 0 rows affected (0.12 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC teacher1;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| addr | varchar(20) | YES | | NULL | |
| id | int(11) | NO | PRI | NULL | |
| sex | char(1) | YES | | NULL | |
| name | varchar(20) | NO | | NULL | |
| age | int(11) | YES | | NULL | |
| birthday | date | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
6 rows in set (0.00 sec)

8、删除一列
语法:alter  table  tab_name  drop  [column] 列名;

mysql>  ALTER TABLE teacher1 DROP sex;
Query OK, 0 rows affected (0.50 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC teacher1;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| addr | varchar(20) | YES | | NULL | |
| id | int(11) | NO | PRI | NULL | |
| name | varchar(20) | NO | | NULL | |
| age | int(11) | YES | | NULL | |
| birthday | date | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

9、修改表名
语法:rename  table  表名  to  新表名;

mysql> RENAME TABLE teacher1 to teacher;
Query OK, 0 rows affected (0.14 sec) mysql> DESC teacher1;
ERROR 1146 (42S02): Table 'teachers.teacher1' doesn't exist
mysql> DESC teacher;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| addr | varchar(20) | YES | | NULL | |
| id | int(11) | NO | PRI | NULL | |
| name | varchar(20) | NO | | NULL | |
| age | int(11) | YES | | NULL | |
| birthday | date | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

10、修该表所用的字符集
语法:alter  table  表名  character  set  编码;

mysql> ALTER TABLE teacher CHARACTER SET gbk;
Query OK, 0 rows affected (0.09 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> SHOW CREATE TABLE teacher;
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| teacher | CREATE TABLE `teacher` (
`addr` varchar(20) CHARACTER SET utf8 DEFAULT NULL,
`id` int(11) NOT NULL,
`name` varchar(20) CHARACTER SET utf8 NOT NULL,
`age` int(11) DEFAULT NULL,
`birthday` date DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk |
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

11、删除除表

语法:drop table table_name

mysql> DROP TABLE teacher;
Query OK, 0 rows affected (0.19 sec) mysql> SHOW TABLES;
Empty set (0.00 sec)

 

补充:MySQL表数据类型

MySQL支持多种数据类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型

数值类型

日期/时间类型

表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。

每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。

字符串类型

字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。

CHAR和VARCHAR类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。

CHAR:指定字符个数

VARCHAR:最大长度

BINARY和VARBINARY类类似于CHAR和VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。

BLOB是一个二进制大对象,可以容纳可变数量的数据。有4种BLOB类型:TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB。它们只是可容纳值的最大长度不同。

有4种TEXT类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。这些对应4种BLOB类型,有相同的最大长度和存储需求。

表记录的操作:下一天

Linux-数据库1的更多相关文章

  1. mysql for linux 数据库的安装过程

    mysql for linux 数据库的安装过程 l  安装版本:mysql-advanced-5.6.12-linux-glibc2.5-x86_64.tar.gz ,此版本是绿色版本,只需要将其解 ...

  2. 使用c语言实现linux数据库的操作

    前言:上一篇讲解了linux下使用命令行操作数据库,这篇继续讲解怎么使用c语言实现linux数据库的操作. 使用c语言实现环境搭建:既然我们要使用c语言实现linux数据库操作,那么首先我们得先把数据 ...

  3. linux数据库备份

    linux数据库备份 服务端启用二进制日志 如果日志没有启开,必须启用binlog,要重启mysql,首先,关闭mysql,打开/etc/my.cnf,加入以下几行: [mysqld] log-bin ...

  4. DELPHI10.2的LINUX数据库开发环境配置

    DELPHI10.2的LINUX数据库开发环境配置 ubuntu使用firedac访问mysql1.安装mysql-client包sudo apt-get install mysql-client m ...

  5. Linux数据库的导入导出

    Linux数据库的导入导出 1.导入数据库 mysql -u username -p test < /home/data/test.sql 说明:username是数据库用户名,test为目标数 ...

  6. linux数据库常用指令

    linux数据库环境搭建好之后,我们就可以创建数据库了,如果不是 很了解linux数据库环境搭建的话,可以到看看我上一篇文章linux数据库环境搭建 首先我们来创建一个数据库:使用指令sqlite3 ...

  7. linux数据库

    sudo apt-get install mysql-server ---------Centos7下安装mysql 开始-------------下载mysql的repo源# yum install ...

  8. 讲解Linux数据库安装

    学习了linux这门课之后,就开始实践过程了,这样比较记得牢固,学以致用. 有了基本的命令,就可以试着安装数据库了. 企业环境 需要安装VMWare ESXi虚拟机,然后再在里面新建虚拟机. 镜像vm ...

  9. kali linux 数据库分析工具简述

    bbqsql SQL盲注可能很难被利用. 当可用的工具工作时,它们运行良好,但是当它们不工作时,您必须编写自定义的东西. 这是耗时且乏味的. BBQSQL可以帮助你解决这些问题. BBQSQL是一个用 ...

  10. Linux数据库的创建 导入导出 以及一些基本指令

    首先linux 下查看mysql相关目录 查看 mysql 的安装路径 执行查询 SQL mysql>show variables like '%dir%'; datadir 就是数据路径 确定 ...

随机推荐

  1. NOIP 2015 提高组 Day1

    期望得分:100+100+100=300 实际得分:100+100+45=245 T3 相似的代码 复制过去 没有改全,痛失55分 http://www.cogs.pro/cogs/page/page ...

  2. HDU6128 二次剩余/二次域求二次剩余解/LL快速乘法取模

    LINK 题意:求满足模p下$\frac{1}{a_i+a_j}\equiv\frac{1}{a_i}+\frac{1}{a_j}$的对数,其中$n,p(1\leq n\leq10^5,2\leq p ...

  3. 你知道吗?Java开发的10位牛人

    James Gosling 1983年,Gosling获得了加州大学的计算机科学学士学位.1990年,他获得了卡内基梅隆大学的计算机科学博士学位,师从Bob Sproull.在攻读博士期间,他自己开发 ...

  4. asp.net DataTable导出 excel的方法记录(第三方)

    官网:http://npoi.codeplex.com/ 简单应用,主要是可以实现我们想要的简单效果,呵呵 需要引入dll,可以在官网下载,也可在下面下载 protected void getExce ...

  5. javascript中各类的prototype属性

    prototype 作用:获取调用对象的对象原型引用 应用:可以为某对象原型添加方法 例: function getMax() { var max = this[0]; for(var x=0; x& ...

  6. 【BZOJ】1901: Zju2112 Dynamic Rankings

    [题意]带修改的查询区间第k小 [算法]树状数组套可持久化线段树 [题解]对于树状数组上的每个节点,维护可持久化权值线段树(节点为权值),从而达到查询前缀和的目的. 对于每次修改,在待修改线段树基础上 ...

  7. 大聊Python----装饰器

    什么是装饰器? 装饰器其实和函数没啥区别,都是用def去定义的,其本质就是函数,而功能就是装饰其他的函数,说白了就是为其他函数提供附加功能 装饰器有什么作用? 比如你是一个公司的员工,你所写的程序里有 ...

  8. Flask 的一个小应用程序

    传说这是Flask 的最小应用程序:hello.py from flask import Flask app = Flask(__name__) @app.route('/') def hello_w ...

  9. linux 下 genymotion 模拟器不能安装app

    提示: "应用未安装" 解决方法: 下载: Genymotion-ARM-Translation_v1.1.zip 进入genymotion 的tools用adb传进去: ./ad ...

  10. 64_p6

    polkit-kde-5.10.1-1.fc26.x86_64.rpm 12-Jun-2017 13:45 84854 polkit-libs-0.113-8.fc26.i686.rpm 13-Apr ...