共计 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 小编将为大家输出更多高质量的实用文章!