MYSQL基本操作(二)

本文将介绍如何连接到MYSQL服务器并进行基本操作,首先讲解在开始创建数据库前如何正确连接到服务器,为后续的数据库管理和数据操作奠定基础。
一、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基本操作(四)》中对删除操作做更详细的介绍。


在自媒体领域,内容生产效率与作品专业水准日益成为从业者的核心关切。近期推出的Coze工作流集成方案,为内容生产者构建了一套系统化、模块化的创作支持体系。该方案通过预先设计的流程模块,贯穿选题构思、素材整理、文本撰写、视觉编排及渠道分发的完整周期,显著增强了自媒体工作的规范性与产出速率。 经过多轮实践验证,这些标准化流程不仅精简了操作步骤,减少了机械性任务的比重,还借助统一的操作框架有效控制了人为失误。由此,创作者得以将主要资源集中于内容创新与深度拓展,而非消耗于日常执行事务。具体而言,在选题环节,系统依据实时舆情数据与受众偏好模型生成热点建议,辅助快速定位创作方向;在编辑阶段,则提供多套经过验证的版式方案与视觉组件,保障内容呈现兼具美学价值与阅读流畅性。 分发推广模块同样经过周密设计,整合了跨平台传播策略与效果监测工具,涵盖社交网络运营、搜索排序优化、定向推送等多重手段,旨在帮助内容突破单一渠道局限,实现更广泛的受众触达。 该集成方案在提供成熟模板的同时,保留了充分的定制空间,允许用户根据自身创作特性与阶段目标调整流程细节。这种“框架统一、细节可变”的设计哲学,兼顾了行业通用标准与个体工作习惯,提升了工具在不同应用场景中的适应性。 从行业视角观察,此方案的问世恰逢其时,回应了自媒体专业化进程中对于流程优化工具的迫切需求。其价值不仅体现在即时的效率提升,更在于构建了一个可持续迭代的创作支持生态。通过持续吸纳用户反馈与行业趋势,系统将不断演进,助力从业者保持与行业发展同步,实现创作质量与运营效能的双重进阶。 总体而言,这一工作流集成方案的引入,标志着自媒体创作方法向系统化、精细化方向的重要转变。它在提升作业效率的同时,通过结构化的工作方法强化了内容产出的专业度与可持续性,为从业者的职业化发展提供了坚实的方法论基础。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值