MYSQL基本操作(二)

本文将介绍如何连接到MYSQL服务器并进行基本操作,首先讲解在开始创建数据库前如何正确连接到服务器,为后续的数据库管理和数据操作奠定基础。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、MYSQL数据库的创建、使用

1、在创建数据库之前先连接MYSQL服务器;

mysql> -u '用户名' -p '密码'

远程登录:
mysql> -u'username' -p'password' -h'host'

2、创建数据库:
create database <数据库名>

例如创建一个名为Test的数据库:
mysql>create database Test;

3、查看创建的数据库:
mysql>show databases;

4、为数据库添加新用户并分配权限:
命令:GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP,ALTER ON 数据库名.* TO 数据库名@localhost IDENTIFIED BY '密码';

例如:
(1)给来自10.163.225.87的用户joe分配可对数据库vtdc的employee表进行select,insert,update,delete,create,drop等操作的权限,并设定口令为123:
mysql>grant select,insert,update,delete,create,drop on vtdc.employee to joe@10.163.225.87 identified by ‘123′;

(2)给来自10.163.225.87的用户joe分配可对数据库vtdc所有表进行所有操作的权限,并设定口令为123:
mysql>grant all privileges on vtdc.* to joe@10.163.225.87 identified by ‘123′;

(3)增加一个用户,用户名为system,密码为manager。注意要使用PASSWORD函数,然后还要使用FLUSH PRIVILEGES来执行确认。
mysql> INSERT INTO mysql.user (Host,User,Password) VALUES

  ('%','system', PASSWORD('manager'));

mysql> FLUSH PRIVILEGES 

5、设置密码:
命令:SET PASSWORD FOR '数据库名'@'localhost' = OLD_PASSWORD('密码');

设置system用户的密码为manager
mysql> SET PASSWORD FOR system@"%" = PASSWORD('manager');

6、查看当前使用的数据库:
mysql>select database();

7、删除数据库
命令:drop database <数据库名>

二、创建数据表
1、连接数据库:
在创建表之前,我们需要选择是在哪个数据库文件中创建表。所以需要连接到该数据库:
命令: use <数据库名>

切换到其他数据库也可以直接使用该命令。
2、建表:

SQL中基本域类型:
char(n) : 固定长度的字符串,用户指定长度n。也可以用全称character;
varchar(n) : 可变长度的字符串,用户指定最大长度n。等价于全称character varying;
int : 整型类型;
smallint : 小整数类型;
numeric(p, d) :定点数,精度由用户指定,这个数字有p位数(还有一个符号位),其中d位数字在小数点右边;
real,double :浮点数与双精度浮点数;
float(n) : 精度至少为n为的浮点数。

命令:create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]);

例如,建立一个名为MyClass的表:


字段名

数据类型

数据宽度

是否为空

是否为主键

自动增加

默认值

id

int

4

primary key

auto_increment


name

char

20




sex

char

1



’M‘

score

double

16





mysql> create table MyClass(
> id int(4) not null primary key auto_increment,
> name char(20) not null,
> sex char(1) not null default 'M',
> score double(16,2));

3、查看当前数据库里面有几张表:
mysql>show tables;

第一栏会显示当前数据库,下面会列出该数据库中所有的表。
4、获取表结构:
命令: desc 表名,或者show columns from 表名

使用MySQL数据库desc 表名时,Key那一栏,可能会有4种值,即' ','PRI','UNI','MUL'。
(1). 如果Key是空的, 那么该列值的可以重复, 表示该列没有索引, 或者是一个非唯一的复合索引的非前导列;
(2). 如果Key是PRI, 那么该列是主键的组成部分;
(3). 如果Key是UNI, 那么该列是一个唯一值索引的第一列(前导列),并别不能含有空值(NULL);
(4). 如果Key是MUL, 那么该列的值可以重复, 该列是一个非唯一索引的前导列(第一列)或者是一个唯一性索引的组成部分但是可以含有空值NULL。

如果对于一个列的定义,同时满足上述4种情况的多种,比如一个列既是PRI,又是UNI,那么"desc 表名"的时候,显示的Key值按照优先级来显示 PRI->UNI->MUL。那么此时,显示PRI。

一个唯一性索引列可以显示为PRI,并且该列不能含有空值,同时该表没有主键。
一个唯一性索引列可以显示为MUL, 如果多列构成了一个唯一性复合索引,因为虽然索引的多列组合是唯一的,比如ID+NAME是唯一的,但是没一个单独的列依然可以有重复的值,只要ID+NAME是唯一的即可。

5、删除数据表
命令:drop table <表名>

例如:删除表名为 MyClass 的表
mysql> drop table MyClass;

DROP TABLE用于取消一个或多个表。但是必须有每个表的DROP权限。所有的表数据和表定义会被取消,所以使用本语句要小心!

注意:对于一个带分区的表,DROP TABLE会永久性地取消表定义,取消各分区,并取消储存在这些分区中的所有数据。DROP TABLE还会取消与被取消的表有关联的分区定义(.par)文件。
对与不存在的表,使用IF EXISTS用于防止错误发生。当使用IF EXISTS时,对于每个不存在的表,会生成一个NOTE。
例如,现在想删除一张不存在的表TEST,就可以:
mysql>drop table if exists TEST;


PS:准备在后面的文章《MYSQL基本操作(四)》中对删除操作做更详细的介绍。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值