mysql/mariadb学习记录——创建删除数据库、表的基本命令
查看已有的数据库:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| test |
+--------------------+
rows in set (0.05 sec)
新建数据库语句:
mysql> create database wzu;
Query OK, row affected (0.05 sec) mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| test |
| wzu |
+--------------------+
rows in set (0.05 sec)
要对某个数据库进行操作时首先要选中这个数据库,使用use <dbname>:
mysql> use wzu
Database changed
创建表格:
命令:create table <表名> ( <属性名 属性类型 [修饰]> );
create table student(sno char(9) primary key,sname char(20) unique,ssex char(2),sage smallint, sdept char(20));
create table course(cno char(4) primary key,cname char(40) not null,cpno char(4),ccredit smallint,foreign key(cpno) references course(cno));
create table sc(sno char(9),cno char(4),grade smallint,primary key(sno,cno),foreign key(sno) references student(sno),foreign key(cno) references course(cno));
删除表格:
命令:drop table <表名>;
mysql> drop table emp;
Query OK, rows affected (0.41 sec)
查看数据库中有哪些表格:
mysql> show tables;
+---------------+
| Tables_in_wzu |
+---------------+
| course |
| sc |
| student |
+---------------+
更改外键约束:
set foreign_key_checks=; //忽略外键检查
set foreign_key_checks=; //重启外键检查
更改表中某属性的数据类型:
命令:alter table <表名> modify <需要更改的属性> <想要更改的类型>;
如:student 表中的sno字段改成varchar(11)
mysql> alter table student modify sno varchar();
Query OK, rows affected (0.15 sec)
Records: Duplicates: Warnings:
可以用desc <表名> 来查看表格结构:
mysql> desc student;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| sno | varchar() | NO | PRI | | |
| sname | varchar() | YES | UNI | NULL | |
| ssex | varchar() | YES | | NULL | |
| sage | smallint() | YES | | NULL | |
| sdept | varchar() | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
表格插入数据:
命令:insert into <表名> values( 填,入,相,应,的,值 );
insert into student values('','测试','男','','CS');
删除一行数据:
命令:delete from <表名> where [条件];
mysql> delete from emp where empno='';
修改一行数据:
命令:update <表名> set [属性名]=[值] [where] [条件]
mysql> update course set cpno=null where cpno='NULL';
表格中的简单数据查询:
select * from [表名]
如:select * from student;
* 表示查询表格中所有的列,也可以用列名加','隔开来选择自己需要的数据
mysql> select * from student;
+-------------+--------+------+------+-------+
| sno | sname | ssex | sage | sdept |
+-------------+--------+------+------+-------+
| | 测试 | 男 | | CS |
| | 周帅 | 男 | | CS |
+-------------+--------+------+------+-------+ mysql> select sno,sname from student;
+-------------+--------+
| sno | sname |
+-------------+--------+
| | 测试 |
| | 周帅 |
+-------------+--------+
给已创建的表格增加一栏属性:
alter table <表名> add <属性名> <属性域>;
如:
mysql> alter table dept add type varchar();
Query OK, rows affected (0.62 sec)
Records: Duplicates: Warnings: mysql> desc dept;
+--------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+--------------+------+-----+---------+-------+
| deptno | decimal(,) | NO | PRI | NULL | |
| dname | varchar() | NO | | NULL | |
| loc | varchar() | YES | | NULL | |
| type | varchar() | YES | | NULL | |
+--------+--------------+------+-----+---------+-------+
在已创建的表格中删除一栏属性:
alter table <表名> drop <属性名>;
如:
mysql> alter table dept drop type;
Query OK, rows affected (0.57 sec)
Records: Duplicates: Warnings: mysql> desc dept;
+--------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+--------------+------+-----+---------+-------+
| deptno | decimal(,) | NO | PRI | NULL | |
| dname | varchar() | NO | | NULL | |
| loc | varchar() | YES | | NULL | |
+--------+--------------+------+-----+---------+-------+
当发现一个操作有warning时 可以通过show warnings;来查看警告信息:
mysql> show warnings;
+---------+------+-----------------------------------------------------------------------------------+
| Level | Code | Message |
+---------+------+-----------------------------------------------------------------------------------+
| Warning | 1366 | Incorrect string value: '\xE6\x9D\x8E\xE5\x8B\x87' for column 'sname' at row 1 |
| Warning | 1366 | Incorrect string value: '\xE7\x94\xB7' for column 'ssex' at row 1 |
| Warning | 1366 | Incorrect string value: '\xE6\x95\xB0\xE6\x8D\xAE...' for column 'cname' at row 1 |
+---------+------+-----------------------------------------------------------------------------------+
此处的问题主要是因为插入的编码格式不兼容(插入的数据编码为utf8 表格的编码为latinl)
解决方法见mysql/mariadb学习过程中出现的问题与解决
mysql查看当前选择的数据库:
mysql> select database();
+------------+
| database() |
+------------+
| groupdb |
+------------+
//或者:
mysql> show tables;
+-------------------+
| Tables_in_groupdb |//此处为当前数据库
+-------------------+
| course |
| dept |
| emp |
| jwc |
| salgrade |
| sc |
| student |
| temp |
+-------------------+
//或者:
mysql> status;
--------------
mysql Ver 14.14 Distrib 5.7.14, for Win64 (x86_64)
Connection id: 2721
Current database: groupdb //此处为当前数据库
Current user: group@122.228.131.86
SSL: Not in use
Using delimiter: ;
Server version: 5.5.56-MariaDB MariaDB Server
Protocol version: 10
Connection: AAA.AAA.AAA.AAA via TCP/IP
Server characterset: utf8
Db characterset: utf8
Client characterset: utf8
Conn. characterset: utf8
TCP port: 3306
Uptime: 2 days 5 hours 25 min 51 sec
Threads: 2 Questions: 549 Slow queries: 0 Opens: 26 Flush tables: 2 Open tables: 44 Queries per second avg: 0.002
2018-04-30
判断一个值是否为NULL:
使用 is 关键字而不能用 = 来判断
mysql> select * from course where cpno is null;
+-----+--------------+------+---------+
| cno | cname | cpno | ccredit |
+-----+--------------+------+---------+
| | 高等数学 | NULL | |
| | 数据处理 | NULL | |
+-----+--------------+------+---------+
rows in set (0.05 sec) mysql> select * from course where cpno is not null;
+-----+--------------+------+---------+
| cno | cname | cpno | ccredit |
+-----+--------------+------+---------+
| | 数据库 | | |
| | 信息系统 | | |
| | 操作系统 | | |
| | 数据结构 | | |
| | C语言 | | |
+-----+--------------+------+---------+
mysql/mariadb学习记录——创建删除数据库、表的基本命令的更多相关文章
- mysql/mariadb学习记录——查询
连接查询:同时设计两个及以上的表的查询 连接条件或连接谓词:用来连接两个表的条件一般格式: [<表名1>]<列名1> <比较运算符> [<表名2>]&l ...
- mysql/mariadb学习记录——查询2
Alias——使用一个列名别名AS 关键字: mysql> select sno as studentId,sname as studentName from student; +------- ...
- mysql/mariadb学习记录——limit
在mysql/mariadb 中可以用limit来限制查询的条数.例子如下: 1.limit后加一个参数 limit n: //选中查询所有结果中的前两条记录并返回 mysql> ; +---- ...
- mysql/mariadb学习记录——连接查询(JOIN)
//本文使用的数据表格//persons表中id_p为主键//orders表中id_o为主键,id_p为外键参考persons表中的id_p mysql> select * from perso ...
- mysql/mariadb学习记录——查询3(AVG、SUM、COUNT)函数
AVG() 求平均数函数: //求emp表中的sal属性的平均值 mysql> select avg(sal) as salAverage from emp; +-------------+ | ...
- --oracle删除数据库表(无主键)中重复的记录
--oracle删除数据库表(无主键)中重复的记录 1, CREATE TABLE newtable as SELECT distinct * FROM T_SYSTEM_MENU_PRIV; 2, ...
- Django学习路5_更新和删除数据库表中元素
查找所有的元素 Student.objects.all() 查找单个元素 Student.objects.get(主键=值) 主键 pk = xxx 更新数据库数据后进行保存 stu.save() 删 ...
- Java创建Oracle数据库表
我们通常只用java执行DML(即:insert, update, delete, select)操作,很少用来执行DDL(create, drop, alert)操作.今天试了下如何用java来创建 ...
- Mysql命令drop database:删除数据库
drop命令用于删除数据库. drop命令格式:drop database <数据库名>; 例如,删除名为 xhkdb的数据库:mysql> drop database xhkdb; ...
随机推荐
- 漂亮的ActionBar效果
Newsstand—这个应用引进了新的方式,使得ActionBar达到了新的水平.如果你打开这个应用的发布页,你会注意到不带图标的ActionBar是半透明的,而且和一个大的图片集(一个大的杂志图标, ...
- 【Java】得到当前股票信息
import java.io.BufferedReader; import java.io.InputStreamReader; import java.net.HttpURLConnection; ...
- vo、po、dto、bo、pojo、entity、mode如何区分
https://blog.csdn.net/qq_41604862/article/details/79675223?utm_source=blogxgwz0
- leveldb源码分析--Key结构
[注]本文参考了sparkliang的专栏的Leveldb源码分析--3并进行了一定的重组和排版 经过上一篇文章的分析我们队leveldb的插入流程有了一定的认识,而该文设计最多的又是Batch的概念 ...
- scrapy实战--登陆人人网爬取个人信息
今天把scrapy的文档研究了一下,感觉有点手痒,就写点东西留点念想吧,也做为备忘录.随意写写,看到的朋友觉得不好,不要喷我哈. 创建scrapy工程 cd C:\Spider_dev\app\scr ...
- 【Kettle】2、文件夹与界面介绍
1.文件夹介绍 下载Kettle6.1解压后出现下图相关文件夹以及文件夹介绍说明: Lib:存放Kettle的核心(core)jar包.工作引擎(engine)jar包.数据库(DB) jar包.图形 ...
- 奇怪的等待事件“enq: ss - contention”
数据库有时会遇到大量的进程发生'enq: ss - contention'等待,持续5到10分钟,然后自动消失.从字面上看,'SS'是Sort Segment: select * from v$loc ...
- Aiseesoft Data Recovery 1.1.6 专业数据恢复软件破解版
Aiseesoft Data Recovery是专业的数据恢复软件,它可以帮助你恢复几乎所有删除/丢失的文件,如照片,文件,电子邮件,音频,视频且支持从计算机,硬盘驱动器,闪存驱动器,存储卡,数码相机 ...
- Hadoop HBase概念学习系列之HBase表的一些设置(强烈推荐好好领悟)(十三)
压缩格式:默认压缩格式是NONE.可选值有GZ.LZO.SNAPPY. 版本数:HBase默认定义为3个版本. 以秒为单位的存活时间TTL:使用对象是行中的列簇,一旦达到过期时间,HBase会删除这些 ...
- October 07th 2017 Week 40th Saturday
Knowledge is a treasure but practice is the key to it. 知识是宝藏,但实践才是打开它的钥匙. Experience often comes fro ...