zoukankan      html  css  js  c++  java
  • Mysql数据库相关

    数据库

    1. 连接Mysql

    连接Mysql:格式: mysql -h主机地址 -u用户名 -p用户密码

    键入命令mysql -u root -p,回车后提示你输密码

    2. 退出Mysql

    exit回车

    3.显示数据库

    命令:mysql> show databases;

    4. 创建数据库

    命令:create database <数据库名>

    例:建立一个名为newdatabase的数据库 mysql> create database newdatabase;

    5. 删除数据库

    命令:drop database <数据库名>例如:删除名为newdatabase的数据库mysql> drop database newdatabase;

    6.连接数据库

    命令: use <数据库名>

    例如:如果newdatabase数据库存在,尝试存取它: mysql> use newdatabase;屏幕提示:Database changed

    use 语句可以通告MySQL把db_name数据库作为默认(当前)数据库使用,用于后续语句。该数据库保持为默认数据库,直到语段的结尾,或者直到发布一个不同的USE语句:

     mysql> USE db1; mysql> SELECT COUNT(*) FROM mytable;   # selects from db1.mytable
     mysql> USE db2; mysql> SELECT COUNT(*) FROM mytable;   # selects from db2.mytable​

    使用USE语句为一个特定的当前的数据库做标记,不会阻碍您访问其它数据库中的表。下面的例子可以从db1数据库访问作者表,并从db2数据库访问编辑表:


       mysql> USE db1;  
       mysql> SELECT author_name,editor_name FROM author,db2.editor       ->        WHERE author.editor_id = db2.editor.editor_id;

    7.当前选择的数据库

     

    数据表

    1. 创建数据表

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

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

    mysql> create table MyClass(> id int(4) not null,> name char(20) not null,> sex int(4) not null default '0',> degree double(16,2));

    1. 删除数据表

    1. 查询表中数据

    1)、查询所有行命令: select <字段1,字段2,...> from < 表名 > where < 表达式 >例如:查看表 MyClass 中所有数据 mysql> select * from MyClass;

    2)、查询前几行数据例如:查看表 MyClass 中前2行数据mysql> select * from MyClass order by id limit 0,2;

    select一般配合where使用,以查询更精确更复杂的数据。

    1. 表中插入数据

    命令:insert into <表名> [( <字段名1>[,..<字段名n > ])] values ( 值1 )[, ( 值n )]

    例如:往表 MyClass中插入二条记录, 这二条记录表示:编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99, 编号为3 的名为Wang 的成绩为96.5。 mysql> insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59);

    注意:insert into每次只能向表中插入一条记录。

    1. 删除表中数据

    命令:delete from 表名 where 表达式

    例如:删除表 MyClass中编号为1 的记录mysql> delete from MyClass where id=1;

    1. 修改表中数据

    语法:update 表名 set 字段=新值,… where 条件 mysql> update MyClass set name='Mary' where id=1;

    例子1:单表的MySQL UPDATE语句: UPDATE LOW_PRIORITY tbl_name SET col_name1=expr1 , col_name2=expr2 ... ORDER BY ...

    例子2:多表的UPDATE语句:UPDATE LOW_PRIORITY table_references SET col_name1=expr1 , col_name2=expr2 ...

    UPDATE语法可以用新值更新原有表行中的各列。SET子句指示要修改哪些列和要给予哪些值。WHERE子句指定应更新哪些行。如果没有WHERE子句,则更新所有的行。如果指定了ORDER BY子句,则按照被指定的顺序对行进行更新。LIMIT子句用于给定一个限值,限制可以被更新的行的数目。

    1. 增加字段

    命令:alter table 表名 add字段 类型 其他;例如:在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0 mysql> alter table MyClass add passtest int(4) default '0'

    加索引 mysql> alter table 表名 add index 索引名 (字段名1[,字段名2 …]);例子: mysql> alter table employee add index emp_name (name);

    加主关键字的索引 mysql> alter table 表名 add primary key (字段名);例子: mysql> alter table employee add primary key(id);

    加唯一限制条件的索引 mysql> alter table 表名 add unique 索引名 (字段名);例子: mysql> alter table employee add unique emp_name2(cardnumber);

    删除某个索引 mysql> alter table 表名 drop index 索引名;例子: mysql>alter table employee drop index emp_name;

    增加字段:mysql> ALTER TABLE table_name ADD field_name field_type;

    修改原字段名称及类型:mysql> ALTER TABLE table_name CHANGE old_field_name new_field_name field_type;

    删除字段:MySQL ALTER TABLE table_name DROP field_name;

    1. 修改表名

    命令:rename table 原表名 to 新表名;

    例如:在表MyClass名字更改为YouClass mysql> rename table MyClass to YouClass;

    当你执行 RENAME 时,你不能有任何锁定的表或活动的事务。你同样也必须有对原初表的 ALTER 和 DROP 权限,以及对新表的 CREATE 和 INSERT 权限。

    如果在多表更名中,MySQL 遭遇到任何错误,它将对所有被更名的表进行倒退更名,将每件事物退回到最初状态。

    RENAME TABLE 在 MySQL 3.23.23 中被加入。

    1. 备份数据

    命令在DOS的[url=file://mysqlin]mysqlin[/url]目录下执行

    1.导出整个数据库导出文件默认是存在mysqlin目录下

    mysqldump -u 用户名 -p 数据库名 > 导出的文件名mysqldump -u user_name -p123456 database_name > outfile_name.sql

    2.导出一个表

    mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名mysqldump -u user_name -p database_name table_name > outfile_name.sql

    3.导出一个数据库结构

    mysqldump -u user_name -p -d –add-drop-table database_name > outfile_name.sql-d 没有数据 –add-drop-table 在每个create语句之前增加一个drop table

    4.带语言参数导出

    mysqldump -uroot -p –default-character-set=latin1 –set-charset=gbk –skip-opt database_name > outfile_name.sql

    例如,将aaa库备份到文件back_aaa中:  [root@test1 root]# cd /home/data/mysql  [root@test1 mysql]# mysqldump -u root -p --opt aaa > back_aaa

    1. 实例1

    drop database if exists school; //如果存在SCHOOL则删除create database school; //建立库SCHOOLuse school; //打开库SCHOOLcreate table teacher //建立表TEACHER(    id int(3) auto_increment not null primary key,    name char(10) not null,    address varchar(50) default ‘深圳’,    year date); //建表结束

    //以下为插入字段

    insert into teacher values(”,’allen’,'大连一中’,'1976-10-10′);insert into teacher values(”,’jack’,'大连二中’,'1975-12-23′);

    如果你在mysql提示符键入上面的命令也可以,但不方便调试。1、你可以将以上命令原样写入一个文本文件中,假设为school.sql,然后复制到c:下,并在DOS状态进入目录[url=file://mysqlin]mysqlin[/url],然后键入以下命令:

    mysql -uroot -p密码 < c:\school.sql

    如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你只要将//的注释去掉即可使用)。

    2、或者进入命令行后使用 mysql> source c:school.sql; 也可以将school.sql文件导入数据库中。

     
  • 相关阅读:
    完爆!用边缘容器,竟能秒级实现团队七八人一周的工作量
    手把手教你使用 cert-manager 签发免费证书
    手把手教你使用 Nginx Ingress 实现金丝雀发布
    Codeforces 534B Covered Path 贪心
    Codeforces 534A Exam 水
    Topcoder open 2015 Round 1A 250 Similars 枚举 + 状压
    Topcoder SRM 654 DIV1 500 FoldingPaper2 递归 + 枚举
    Topcoder SRM655 DIV2 250 BichromeBoard 水
    2015 Google code jam Qualification Round B 枚举 + 贪心
    2015 Google code jam Qualification Round A 水
  • 原文地址:https://www.cnblogs.com/carleunderwood/p/7149793.html
Copyright © 2011-2022 走看看