Mysql初识
Posted qq752059037
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql初识相关的知识,希望对你有一定的参考价值。
什么是数据库:
数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,
每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据。
我们也可以将数据存储在文件中,但是在文件中读写数据速度相对较慢。
所以,现在我们使用关系型数据库管理系统(RDBMS)来存储和管理的大数据量。所谓的关系型数据库,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据。
RDBMS即关系数据库管理系统(Relational Database Management System)的特点:
- 1.数据以表格的形式出现
- 2.每行为各种记录名称
- 3.每列为记录名称所对应的数据域
- 4.许多的行和列组成一张表单
- 5.若干的表单组成database
术语:
- 数据库: 数据库是一些关联表的集合。
- 数据表: 表是数据的矩阵。在一个数据库中的表看起来像一个简单的电子表格。
- 列: 一列(数据元素) 包含了相同的数据, 例如邮政编码的数据。
- 行:一行(=元组,或记录)是一组相关的数据,例如一条用户订阅的数据。
- 表头(header): 每一列的名称;
- 列(row): 具有相同数据类型的数据的集合;
- 行(col): 每一行用来描述某条记录的具体信息;
- 值(value): 行的具体信息, 每个值必须与该列的数据类型相同;
- 键(key): 键的值在当前列中具有唯一性。
简单来说
库 相当于文件夹 一般每个程序使用一个库
表 相当于一篇文件
记录 就是一条信息
关系型 : 一条数据包含了一个事物的多条信息,这些信息之间是有关联性的 比如 1,clare,clare1210,21,13145005201
非关系型 : 存取频繁的,并且要求效率高的,不突出数据之间关联的 比如 id content
关系型数据库
- mysql 开源
- oracle 企业级的
- sqlite 轻量级
- sql server 一般大学使用的
非关系型数据库 :一般用作消息转发
- memcache
- redis
- MongoDB
- nosql
MySQL数据库简介
MySQL数据库
MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
- MySQL 是开源的,所以不需要支付额外的费用。
- MySQL 支持大型的数据库。可以处理拥有上千万条记录的大型数据库。
- MySQL 使用标准的SQL数据语言形式。
- MySQL 可以运行于多个系统上,并且支持多种语言。这些编程语言包括C、C++、Python、Java、Perl、php、Eiffel、Ruby和Tcl等。
- MySQL 对PHP有很好的支持,PHP是目前最流行的Web开发语言。
- MySQL 支持大型数据库,支持5000万条记录的数据仓库,32位系统表文件最大可支持4GB,64位系统支持最大的表文件为8TB。
- MySQL 是可以定制的,采用了GPL协议,你可以修改源码来开发自己的 MySQL 系统。
相关操作
启动/停止/登陆/
注意: MySQL语句以分号(;)作为语句的结束, 若在语句结尾不添加分号时, 命令提示符会以 -> 提示你继续输入(有个别特例, 但加分号是一定不会错的);
- 启动服务: net start MySQL
- 停止: net stop MySQL
- 卸载: sc delete MySQL
- 登陆(需已启动服务): mysql -h主机名 -u 用户名 -p;
-h : 该命令用于指定客户端所要登录的MySQL主机名, 登录当前机器该参数可以省略; -u : 所要登录的用户名; -p : 告诉服务器将会使用一个密码来登录, 如果所要登录的用户名密码为空, 可以忽略此选项。
创建库
- 创建数据库 create database 数据库名 [其他选项];
例如我们需要创建一个名为 userinfo 的数据库, 在命令行下执行以下命令:
create database userinfo character set gbk;
为了便于在命令提示符下显示中文, 在创建时通过 character set gbk 将数据库字符编码指定为 gbk。创建成功时会得到 userinfo, 1 row affected(0.02 sec) 的响应
操作库
要对一个数据库进行操作, 必须先选择该数据库, 否则会提示错误:
ERROR 1046(3D000): No database selected
两种方式对数据库进行使用的选择:
一: 在登录数据库时指定, 命令: mysql -D所选择的数据库名 -h主机名 -u用户名 -p
例如登录时选择刚刚创建的数据库: mysql -D userinfo -u root -p
二: 在登录后使用 use 语句指定, 命令: use 数据库名;
use 语句可以不加分号, 执行 use samp_db 来选择刚刚创建的数据库, 选择成功后会提示: Database changed
创建表
使用 create table 语句可完成对表的创建, create table 的常见形式:
- create table 表名称(列声明);
以创建 students 表为例, 表中将存放 学号(id)、姓名(name)、性别(sex)、年龄(age)、联系电话(tel) 这些内容:
create table students ( id int unsigned not null auto_increment primary key, name char(8) not null, sex char(4) not null, age tinyint unsigned not null, tel char(13) null default "-" );
语句解说:
create table tablename(columns) 为创建数据库表的命令, 列的名称以及该列的数据类型将在括号内完成;
括号内声明了5列内容, id、name、sex、age、tel为每列的名称, 后面跟的是数据类型描述, 列与列的描述之间用逗号(,)隔开;
以 "id int unsigned not null auto_increment primary key" 行进行介绍:
- "id" 为列的名称;
- "int" 指定该列的类型为 int(取值范围为 -8388608到8388607), 在后面我们又用 "unsigned" 加以修饰, 表示该类型为无符号型, 此时该列的取值范围为 0到16777215;
- "not null" 说明该列的值不能为空, 必须要填, 如果不指定该属性, 默认可为空;
- "auto_increment" 需在整数列中使用, 其作用是在插入数据时若该列为 NULL, MySQL将自动产生一个比现存值更大的唯一标识符值。在每张表中仅能有一个这样的值且所在列必须为索引列。
- "primary key" 表示该列是表的主键, 本列的值必须唯一, MySQL将自动索引该列。
提示: 1. 使用 show tables; 命令可查看已创建了表的名称; 2. 使用 describe 表名; 命令可查看已创建的表的详细信息。
操作MySQL数据库
向表中插入数据
insert 语句可以用来将一行或多行数据插到数据库表中, 使用的一般形式如下:
- insert [into] 表名 [(列名1, 列名2, 列名3, ...)] values (值1, 值2, 值3, ...);
其中 [] 内的内容是可选的, 例如, 要给 userinfo 数据库中的 students 表插入一条记录, 执行语句:
- insert into students values(NULL, "王刚", "男", 20, "13811371377");
按回车键确认后若提示 Query Ok, 1 row affected (0.05 sec) 表示数据插入成功。 若插入失败请检查是否已选择需要操作的数据库。
有时我们只需要插入部分数据, 或者不按照列的顺序进行插入, 可以使用这样的形式进行插入:
- insert into students (name, sex, age) values("孙丽华", "女", 21);
查询表中的数据
select 语句常用来根据一定的查询规则到数据库中获取数据, 其基本的用法为:
- select 列名称 from 表名称 [查询条件];
例如要查询 students 表中所有学生的名字和年龄, 输入语句
- select name, age from students;
也可以使用通配符 * 查询表中所有的内容, 语句:
- select * from students;
按特定条件查询:
where 关键词用于指定查询条件, 用法形式为:
- select 列名称 from 表名称 where 条件;
以查询所有性别为女的信息为例, 输入查询语句:
- select * from students where sex="女";
where 子句不仅仅支持 "where 列名 = 值" 这种名等于值的查询形式, 对一般的比较运算的运算符都是支持的, 例如 =、>、<、>=、<、!= 以及一些扩展运算符 is [not] null、in、like 等等。 还可以对查询条件使用 or 和 and 进行组合查询
示例:
查询年龄在21岁以上的所有人信息: select * from students where age > 21;
查询名字中带有 "王" 字的所有人信息: select * from students where name like "%王%";
查询id小于5且年龄大于20的所有人信息: select * from students where id<5 and age>20;
更新表中的数据
update 语句可用来修改表中的数据, 基本的使用形式为:
- update 表名称 set 列名称=新值 where 更新条件;
使用示例:
将id为5的手机号改为默认的"-":
- update students set tel=default where id=5;
将所有人的年龄增加1:
- update students set age=age+1;
将手机号为 13288097888 的姓名改为 "张伟鹏", 年龄改为 19:
- update students set name="张伟鹏", age=19 where tel="13288097888";
删除表中的数据
delete 语句用于删除表中的数据, 基本用法为:
- delete from 表名称 where 删除条件;
使用示例:
删除id为2的行:
- delete from students where id=2;
删除所有年龄小于21岁的数据:
- delete from students where age<20;
删除表中的所有数据:
- delete from students;
创建后表的修改
alter table 语句用于创建后对表的修改, 基础用法如下:
添加列
基本形式:
- alter table 表名 add 列名 列数据类型 [after 插入位置];
示例:
在表的最后追加列 address:
- alter table students add address char(60);
在名为 age 的列后插入列 birthday:
- alter table students add birthday date after age;
修改列
- 基本形式: alter table 表名 change 列名称 列新名称 新数据类型;
示例:
将表 tel 列改名为 telphone:
- alter table students change tel telphone char(13) default "-";
将 name 列的数据类型改为 char(16):
- alter table students change name name char(16) not null;
删除列
基本形式:
- alter table 表名 drop 列名称;
示例:
删除 birthday 列:
- alter table students drop birthday;
重命名表
基本形式:
- alter table 表名 rename 新表名;
示例:
重命名 students 表为 workmates:
- alter table students rename workmates;
删除整张表
基本形式:
- drop table 表名;
示例: 删除 workmates 表:
- drop table workmates;
删除整个数据库( 慎用 ! )
基本形式:
- drop database 数据库名;
示例: 删除 samp_db 数据库:
- drop database samp_db;
修改 root 用户密码
按照本文的安装方式, root 用户默认是没有密码的, 重设 root 密码的方式也较多, 这里仅介绍一种较常用的方式。
使用 mysqladmin 方式:
打开命令提示符界面, 执行命令:
- mysqladmin -u root -p password 新密码
执行后提示输入旧密码完成密码修改, 当旧密码为空时直接按回车键确认即可。
以上是关于Mysql初识的主要内容,如果未能解决你的问题,请参考以下文章
初识OpenGL 片段着色器(Fragment Shader)