数据库更改?修改数据库有哪几种方法
大家好,今天来为大家解答数据库更改这个问题的一些问题点,包括修改数据库有哪几种方法也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~
数据库增删改查的基本命令
以下是总结的mysql的常用语句,欢迎指正和补充~
一、创建库,删除库,使用库
1.创建数据库:create database库名;
2.删除数据库:drop database库名;
3.使用数据库:use库名;
二、创建数据表
1.创建表语句:create table表名(字段名1字段类型字段约束,字段2字段类型字段约束...);
2.创建与现有表一样字段的新表:create table表名 like已有表名;
3.将查询结果创建新表:create table表名 select* from现有表 where...(查询语句);
三、查看表结构,查看建表语句,删除表
1.查看表结构:desc表名;
2.查看建表语句:show create table表名;
3.删除表:drop table表名;
四、修改表结构
1.对数据表重命名:alter table表名 rename新表名;
2.增加字段:alter table表名 add字段名字段类型字段约束;(PS:可用first/after函数调整字段位置)
3.删除字段:alter table表名 drop字段名;
4.修改字段类型及约束:alter table表名 modify字段名新类型新约束;(PS:如不加新约束,会将建表时的约束清空,主键、外键、唯一约束除外)
5.修改字段名称:alter table表名 change字段名新字段名新字段类型新约束条件;
6.修改数据库引擎:alter table表名 engine=;(PS:主要有InnoDB和MyISAM,InnoDB对经常修改表数据友好,MyISAM对经常查询表友好)
7.增加主键:alter table表名 add primary key(字段名);
8.删除主键:alter table表名 drop primary key;
9.增加外键:alter table表名 add constraint外键名 foreign kek(字段名) references主表(主键);
10.删除外键:alter table表名 drop foreign key外键名;
11.删除唯一约束:alter table表名 drop index字段名;
12.设置自动增长的初始位置:alter table表名 auto_increment=n;
五、向表中插入数据
1.向表指定字段插入多条数据:insert into表名(字段1,字段2...) values(数据1,数据2...),(数据1,数据2...),(数据1,数据2...),(数据1,数据2...);
2.将查询结果插入表:insert into表名 select字段名 from表名(查询语句);
3.加载外部数据到表:Load data local infile‘数据路径’Into table表名 Fields terminated by‘分隔符’Ignored 1 lines;
六、更新表数据、删除表数据
1.更改满足条件的字段数据:update表名 set字段计算1,字段计算2... where条件;
2.删除满足条件的数据:delele from表名 where条件;
3.删除所有数据:方式一:delete from表名;方式二:truncate table表名;方式一会逐条进行删除,速度较慢,方式二直接删除,速度快;另外对自增字段,方式一不能重置自增字段的初始位置,方式二可以重置自增字段的其实位置;
怎样修改数据库中的数据
1、首先打开SQL Server Management管理工具,使用sql语句创建一张测试表。
2、在测试表中,插入3条测试数据。
3、使用一条语句批量修改整个表的数据。
4、使用一条语句批量修改指定条数的记录。
5、使用一条语句批量修改这三条数据(按条件修改值)。
6、使用一条语句批量修改数据,使用where和case when。
修改数据库有哪几种方法
第一种方法:
renamedatabaseolddbnametonewdbname
这个是5.1.7到5.1.23版本可以用,但是官方不推荐,会有丢失数据的危险
第二种:
1.创建需要改成新名的数据库
2.mysqldum到处要改名的数据库
3.删除原来的旧库
这种方法是安全的,但是如果数据量大,会很耗时
3.第三种:
#!/bin/bash
#假设将sakila数据库名改为new_sakila
#MyISAM直接更改数据库目录下的文件即可
mysql-uroot-p123456-e'createdatabaseifnotexistsnew_sakila'
list_table=$(mysql-uroot-p123456-Nse"selecttable_namefrominformation_schema.TABLESwhereTABLE_SCHEMA='sakila'")
fortablein$list_table
do
mysql-uroot-p123456-e"renametablesakila.$tabletonew_sakila.$table"
done
这里用到了renametable更改表名的命令,但是如果新表名后面加数据库,将会将原来的数据库的表移动到新的数据库,所有这种方法既安全又快速。
如何修改MySQL数据库名称
修改MySQL数据库名称的方法如下:
1.语句修改法:
RENAME DATABASE db_name TO new_db_name
这个语法在mysql 5.1.7中被添加进来,到了5.1.23又去掉了。
2.如果所有表都是MyISAM类型的话,可以改文件夹的名字
把data目录中的db_name目录重命名为new_db_name
3.重命名所有的表
代码如下:
4. mysqldump导出数据再导入
代码如下:
5.使用shell脚本重命名所有的表
代码如下:
关于数据库更改到此分享完毕,希望能帮助到您。