Mysql怎么查看、创建以及更改数据库和表

73次阅读
没有评论

共计 3425 个字符,预计需要花费 9 分钟才能阅读完成。

本篇内容介绍了“Mysql 怎么查看、创建以及更改数据库和表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让丸趣 TV 小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

修改 mysql 数据库密码

方法一:

使用 phpmyadmin,直接修改 Mysql 库的 user 表。或者使用 Navicat for Mysql 直接修改连接属性。

方法二:使用 mysqladmin

#cmd, 运行 DOS,cd 到 mysql 的 bin 文件夹,然后执行如下
D:\Mysql\bin mysqladmin -u root -p password newPwd
#Enter password:(在此输入原密码)
#newPwd 指的是新密码
然后打开 mysql  直接输入新密码即可

格式:mysqladmin - u 用户名 - p 旧密码 password 新密码。

创建数据库、表

SHOW 语句找出服务器上当前存在什么数据库:

mysql 是必需的,因为它描述用户访问权限,test 数据库经常作为用户试身手的工作区。

访问数据库,使用 use 语句

注意 USE,类似 QUIT,不需要一个分号。(如果你喜欢,你可以用一个分号终止这样的语句;这无碍)。

创建数据库

mysql  CREATE DATABASE  库名;
mysql  USE  库名;
mysql  CREATE TABLE  表名  (字段名  VARCHAR(20),  字段名  CHAR(1));
# 创建表  use demo; create table pet( name varchar(20), # 名字
 owner varchar(20), # 主人
 species varchar(20), # 种类
 sex char(1), # 性别
 birth date, # 出生日期
 death date # 死亡日期
)

为了验证你的表是按你期望的方式创建,使用一个 DESCRIBE 语句:

删除数据库:

mysql  DROP DATABASE  库名;

删除数据表:

mysql  DROP TABLE  表名;

将表中记录清空:

mysql  DELETE FROM  表名;

创建表(复杂形式):

# 创建 customer 表: create table customers(
 id int not null auto_increment,
 name char(20) not null,
 address char(50) null,
 city char(50) null,
 age int not null,
 love char(50) not null default  No habbit , primary key(id)
)engine=InnoDB; #SELECT last_insert_id(); 这个函数可以获得返回最后一个 auto_increment 值. # 默认值:default  No habbit , # 引擎类型,多为 engine = InnoDB,如果省略了 engine= 语句,则使用默认的引擎(MyISAM)

  更改表结构:

# 增加一列  alter table pet add des char(100) null;
#删除  alter table pet drop column des;

重命名表:

# 重命名表
rename table pet to animals;

  添加 id 字段

则可操作如下:

# 添加 id 字段  alter table pet add id int not null primary key auto_increment first;

增加外键:

实例参考:tech.ddvip.com/2007-05/118009486725743.html

假如某个电脑生产商,它的数据库中保存着整机和配件的产品信息。用来保存整机产品信息的表叫做 Pc;用来保存配件供货信息的表叫做 Parts。在 Pc 表中有一个字段,用来描述这款电脑所使用的 CPU 型号;在 Parts 表中相应有一个字段,描述的正是 CPU 的型号,我们可以把它想成是全部 CPU 的型号列表。很显然,这个厂家生产的电脑,其使用的 CPU 一定是供货信息表 (parts) 中存在的型号。这时,两个表中就存在一种约束关系(constraint)——Pc 表中的 CPU 型号受到 Parts 表中型号的约束。

表定义:

#parts CREATE TABLE parts (
...  字段定义  ...,
model VARCHAR(20) NOT NULL,
...  字段定义  ...
#pc CREATE TABLE pc (
...  字段定义  ...,
cpumodel VARCHAR(20) NOT NULL,
...  字段定义  ...
};

既然存在在约束关系(constraint),那么就需要设置索引。

设置索引:

若要设置外键,在参照表(referencing table,即 Pc 表) 和被参照表 (referenced table,即 parts 表) 中,相对应的两个字段必须都设置索引(index)。

对 Parts 表:

ALTER TABLE parts ADD INDEX idx_model (model);

这句话的意思是,为 parts 表增加一个索引,索引建立在 model 字段上,给这个索引起个名字叫 idx_model。

对 Pc 表也类似:

ALTER TABLE pc ADD INDEX idx_cpumodel (cpumodel);

事实上这两个索引可以在创建表的时候就设置。这里只是为了突出其必要性。

定义外键:

下面为两张表之间建立前面所述的那种“约束”。因为 pc 的 CPU 型号必须参照 parts 表中的相应型号,所以我们将 Pc 表的 cpumodel 字段设置为“外键”(FOREIGN KEY),即这个键的参照值来自于其他表。

ALTER TABLE pc ADD CONSTRAINT fk_cpu_model FOREIGN KEY (cpumodel) REFERENCES parts(model);

第一行是说要为 Pc 表设置外键,给这个外键起一个名字叫做 fk_cpu_model;

第二行是说将本表的 cpumodel 字段设置为外键;

第三行是说这个外键受到的约束来自于 Parts 表的 model 字段。

级联操作:

技术人员发现,一个月之前输入到 parts 表中的某个系列的 cpu(可能有很多款)的型号全都输错了一个字母,现在需要改正。我们希望的是,当 parts 表中那些 Referenced Column 有所变化时,相应表中的 Referencing Column 也能自动更正。

可以在定义外键的时候,在最后加入这样的关键字:

ON UPDATE CASCADE;

即在主表更新时,子表(们)产生连锁更新动作,似乎有些人喜欢把这个叫“级联”操作。

如果把这语句完整的写出来,就是:

ALTER TABLE pc ADD CONSTRAINT fk_cpu_model FOREIGN KEY (cpumodel) REFERENCES parts(model) ON UPDATE CASCADE;

除了 cascade 外,还有 restrict(中文意思:限制;约束;限定),这里指 (禁止主表变更)、SET NULL(子表相应字段设置为空) 等操作。

那么我们在图形界面可以查看该表的结构:

四、 ALTER DATABASE 语法

ALTER {DATABASE | SCHEMA} [db_name] alter_specification [, alter_specification] ...
alter_specification: [DEFAULT] CHARACTER SET charset_name | [DEFAULT] COLLATE collation_name

ALTER DATABASE 用于更改数据库的全局特性。这些特性储存在数据库目录中的 db.opt 文件中。要使用 ALTER DATABASE,您需要获得数据库 ALTER 权限。

CHARACTER SET 子句用于更改默认的数据库字符集。COLLATE 子句用于更改默认的数据库整序。数据库名称可以忽略,此时,语句对应于默认数据库。也可以使用 ALTER SCHEMA。

“Mysql 怎么查看、创建以及更改数据库和表”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注丸趣 TV 网站,丸趣 TV 小编将为大家输出更多高质量的实用文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-28发表,共计3425字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)