MySQL
文章平均质量分 62
仲永要加油呀
绕了一个很大的圈,希望终能抵达终点。
展开
-
MySQL(3):使用navicat操作MySQL数据库
1.使用图形窗口连接 打开navicat,点击“连接”弹出窗口,按照提示填写连接信息,如下图 连接成功后,会在连接名称下面显示出当前的数据库;双击选中数据库,就可以编辑此数据库;下次再进入此软件时,通过双击完成连接、编辑操作。 注:这里的“ubuntu”只是设置的navicat与MySQL连接的连接名,并非指ubuntu系统。 2.数据库操作 在连接的名称上右...原创 2018-06-20 19:14:38 · 577 阅读 · 0 评论 -
MySQL(17):用户登录实例
1.创建用户表userinfos 表结构为:id、uname、upwd、isdelete 注意:需要对密码进行加密。如果使用md5加密,则密码包含32个字符;如果使用sha1加密,则密码包含40个字符,一般推荐使用这种加密方式。create table userinfos(id int primary key auto_increment,uname varchar(20)...原创 2018-07-04 09:10:59 · 1179 阅读 · 0 评论 -
MySQL(16):参数化、封装
1.sql语句参数化 创建testInsertParam.py文件,向学生表中插入一条数据#encoding=utf-8import pymysqltry: conn=pymysql.connect(host='localhost',port=3306,db='test1',user='root',passwd='mysql',charset='utf8') c...原创 2018-07-03 21:04:55 · 975 阅读 · 0 评论 -
MySQL(15):与python交互的增删改查
1.增加、删除、修改数据 创建test.py文件,向学生表中插入一条数据、删除一条数据、修改一条数据#encoding=utf-8import pymysqltry: conn=pymysql.connect(host='localhost',port=3306,db='test1',user='root',passwd='mysql',charset='utf8')...原创 2018-07-03 20:26:26 · 197 阅读 · 0 评论 -
MySQL(14):与python交互的类型
1.Connection对象 用于建立与数据库的连接 (1)创建对象:调用connect()方法conn=connect(参数列表)参数host:连接的mysql主机,如果本机是'localhost'参数port:连接的mysql主机的端口,默认是3306参数db:数据库的名称参数user:连接的用户名参数password:连接的密码参数charset:通信采用的编...原创 2018-07-03 19:30:13 · 158 阅读 · 0 评论 -
MySQL(13):索引
1.索引的引入 思考:在图书馆中,如何找到一本书呢? 一般的应用系统,读写比例在10:1左右,而且插入操作和更新操作很少出现性能问题,遇到最多的,也是最容易出现问题的,还是一些复杂的查询操作,所以查询语句的优化显然是重中之重。当数据库中数据量很大时,查找数据会变得很慢,而索引能提高数据访问性能。主键和唯一索引,都是索引,可以提高查询速度。 2.建索引时选择列的数据...原创 2018-06-27 20:38:11 · 167 阅读 · 0 评论 -
MySQL(12):自关联
1.将省与市的表合成一个大表 设计省信息的provinces表结构:id、ptitle。 设计市信息的citys表结构:id、ctitle、proid,citys表的proid表示城市所属的省,对应着provinces表的id值 (1)问题:能不能将两个表合成一个表呢? (2)思考:观察两张表发现,citys表比provinces表多一个列proid,其他的列的类型...原创 2018-06-27 20:35:47 · 430 阅读 · 0 评论 -
MySQL(11):视图、事务
1.视图 对于复杂的查询,在多次使用后,维护是一件非常麻烦的事情,这可以通过定义视图解决。视图本质就是对查询的一个封装。 (1)定义视图create view stuscore asselect students.*,scores.score from scoresinner join students on scores.stuid=students.id; (2) ...原创 2018-06-27 20:04:16 · 167 阅读 · 0 评论 -
MySQL(10):内置函数
1.字符串函数 (1)查看字符的ascii码值ascii(str),str是空串时返回0select ascii('a'); (2)查看ascii码值对应的字符char(数字)select char(97); (3)拼接字符串concat(str1,str2...)select concat(12,34,'ab'); (4)包含字符个数length(str)sele...原创 2018-06-27 15:35:30 · 200 阅读 · 0 评论 -
MySQL(2):在VM ware 的Ubuntu虚拟机中安装MySQL
1.安装 在终端输入命令sudo apt-get install mysql-server mysql-client,然后按照提示输入。 2.管理服务 (1)启动 在终端输入命令service mysql start (2)停止 在终端输入命令service mysql stop (3)重启 在终端输入命令service mysql rest...原创 2018-06-20 17:42:08 · 392 阅读 · 0 评论 -
MySQL(1)
1.自学 字符串函数、数学函数、日期时间函数、类型转换函数. 2.数据库优点与分类 数据库系统解决的问题:持久化存储,优化读写,保证数据的有效性. 当前使用的数据库,主要分为两类: (1)文档型,如sqlite,就是一个文件,通过对文件的复制完成数据库的复制。 (2)服务型,如mysql、postgre,数据存储在一个物理文件中,但是需要使用终端以tcp...原创 2018-06-20 17:32:43 · 152 阅读 · 0 评论 -
MySQL(9):关系与外键
1.创建成绩表(scores) 创建成绩表scores,结构中字段为id、学生、科目、成绩。思考:学生列应该存什么信息呢? 答:学生列的数据不是在这里新建的,而应该从学生表引用过来,关系也是一条数据;根据范式要求应该存储学生的编号,而不是学生的姓名等其它信息;同理,科目表也是关系列,引用科目表中的数据。创建表的语句如下create table scores(id int p...原创 2018-06-27 09:16:12 · 188 阅读 · 0 评论 -
MySQL(8):连接、子查询
1.连接查询分类 (1)表A inner join 表B: 表A与表B匹配的行会出现在结果中。 (2)表A left join 表B: 表A与表B匹配的行会出现在结果中,外加表A中独有的数据,未对应的数据使用null填充。 (3)表A right join 表B: 表A与表B匹配的行会出现在结果中,外加表B中独有的数据,未对应的数据使用null填充。 ...原创 2018-06-27 08:52:30 · 267 阅读 · 0 评论 -
MySQL(7):排序、分页、完整select语句
1.排序 为了方便查看数据,可以对数据进行排序。语法:select * from 表名order by 列1 asc|desc,列2 asc|desc,... 将行数据按照列1进行排序,如果某些行列1的值相同时,则按照列2排序,以此类推;默认按照列值从小到大排列;asc从小到大排列,即升序;desc从大到小排序,即降序。查询未删除男生学生信息,按学号降序select * ...原创 2018-06-24 15:11:35 · 8862 阅读 · 0 评论 -
MySQL(6):聚合、分组
1.聚合 为了快速得到统计数据,提供了5个聚合函数 (1)count(*)表示计算总行数,括号中写星与列名,结果是相同的查询学生总数select count(*) from students; (2)max(列)表示求此列的最大值查询女生的编号最大值select max(id) from students where gender=0; (3)min(列)表示求...原创 2018-06-24 11:35:22 · 815 阅读 · 0 评论 -
MySQL(5):查询条件
1.查询的基本语法select * from 表名;//from关键字后面写表名,表示数据来源于是这张表//select后面写表中的列名,如果是*表示在结果中显示表中所有列//在select后面的列名部分,可以使用as为列起别名,这个别名出现在结果集中//如果要查询多个列,之间使用逗号分隔 2.消除重复行 在select后面列前使用distinct可以消除重复的行sel...原创 2018-06-24 11:06:48 · 4822 阅读 · 0 评论 -
MySQL(4):命令脚本操作
1.使用命令连接 (1)连接MySQL 打开终端,运行命令:mysql -uroot -p 回车后输入密码,连接成功后如下图。 (2)退出登录quit或exit (3)退出成功后如下图 (4)登录成功后,输入如下命令查看效果查看版本:select version();显示当前时间:select now(); 注意:在语句结尾要使用分号; 2...原创 2018-06-20 20:08:40 · 191 阅读 · 0 评论 -
Win10通过命令行窗口登录MySQL5.7时出现ERROR 1045 (28000): Access denied for user 'root'@'localhost'的解决办法
1、打开MySQL目录下的my.ini文件,在文件的最后添加一行“skip-grant-tables”,保存并关闭文件。(Win10默认安装,my.ini在C:\ProgramData\MySQL\MySQL Server 5.7。需要注意的是,"C:\ProgramData"为隐藏目录)2、重启MySQL57和MySQL Router服务。3、通过命令行窗口进入MySQL的bin目录...转载 2019-08-22 16:18:32 · 1721 阅读 · 0 评论