当前位置: 首页 > news >正文

怎么推广自己做的网站文佳佳做网站

怎么推广自己做的网站,文佳佳做网站,怎么样模仿一个网站做简历,中国招标信息公开网大家好#xff0c;我是磊哥#xff01;今天给大家分享一些简单好用的数据库优化方式#xff01;1、选择最合适的字段属性Mysql是一种关系型数据库#xff0c;可以很好地支持大数据量的存储#xff0c;但是一般来说#xff0c;数据库中的表越小#xff0c;在它上面执行的…大家好我是磊哥今天给大家分享一些简单好用的数据库优化方式1、选择最合适的字段属性Mysql是一种关系型数据库可以很好地支持大数据量的存储但是一般来说数据库中的表越小在它上面执行的查询也就越快。因此在创建表的时候为了获得更好的性能我们可以将表中字段的宽度舍得尽可能小。例如在定义邮政编码这个字段时如果将其设置为char(255)显然给数据库增加了不必要的空间甚至使用varchar这种类型也是多余的因为char(6)就可以很好地完成了任务。同样的如果可以的话我们应该是用MEDIUMINT而不是BIGINT来定义整形字段。2、尽量把字段设置为NOT NULL在可能的情况下尽量把字段设置为NOT NULL,这样在将来执行查询的时候数据库不用去比较NULL值。对于某些文本字段来说例如“省份”或者“性别”我们可以将他们定义为ENUM(枚举)类型。因为在MySQL中ENUM类型被当做数值型数据来处理而数值型数据被处理起来的速度要比文本类型要快得多。这样我们又可以提高数据库的性能。3、使用连接(JOIN)来代替子查询(Sub-Queries)MySQL从4.1开始支持SQL的子查询。这个技术可以使用select语句来创建一个单例的查询结果然后把这个结果作为过滤条件用在另一个查询中。例如我们要将客户基本信息表中没有任何订单的客户删除掉就可以利用子查询先从销售信息表中将所有发出订单的客户id取出来然后将结果传递给主查询如下图所示如果使用连接(JOIN)来完成这个工作速度将会快很多尤其是当salesinfo表中对CustomerID建有索引的话性能将会更好查询如下连接(JOIN)之所以更有效率一些是因为MySQL不需要在内存中创建临时表来完成这个逻辑上 需要两个步骤的查询工作。另外如果你的应用程序有很多JOIN查询你应该确认两个表中JOIN的字段是被建立过索引的。这样MySQL内部 会启动为你优化JOIN的SQL语句的机制。而且这些被用来JOIN的字段应该是相同的类型的。例如如果你要把DECIMAL字段和一个INT字段JOIN在一起MySQL就无法使用他们的索引。对于那些STRING类型还需要有相同的字符集才行。(两个表的字符集可能不相同)。inner join内连接也叫做等值连接left/right join是外链接。SELECT A.id,A.name,B.id,B.name FROM A LEFT JOIN B ON A.idB.id; SELECT A.id,A.name,B.id,B.name FROM A RIGHT JOIN ON B A.id B.id; SELECT A.id,A.name,B.id,B.name FROM A INNER JOIN ON A.id B.id;经过多方面的证实inner join性能比较快因为inner join是等值连接或许返回的行数比较少。但是我们要记得有些语句隐形的用到了等值连接如SELECT A.id,A.name,B.id,B.name FROM A,B WHERE A.id  B.id;sql中的连接查询有inner join(内连接、left join(左连接)、right join右连接、full join全连接四种方式它们之间其实并没有太大区别仅仅是查询出来的结果有所不同。例如我们有两张表Orders表通过外键Id_P和Persons表进行关联。inner join内连接在两张表进行连接查询时只保留两张表中完全匹配的结果集。我们使用inner join对两张表进行连接查询sql如下SELECT p.LastName, p.FirstName, o.OrderNo FROM Persons p INNER JOIN Orders o ON p.Id_Po.Id_P and 11  --用and连接多个条件 ORDER BY p.LastName查询结果集此种连接方式Orders表中Id_P字段在Persons表中找不到匹配的则不会列出来。注意单纯的select * from a,b是笛卡尔乘积。比如a表有5条数据b表有3条数据那么最后的结果有5*315条数据。但是如果对两个表进行关联:select * from a,b where a.id b.id 意思就变了此时就等价于select * from a inner join b on a.id b.id。 -- 即就是内连接。但是这种写法并不符合规范可能只对某些数据库管用如sqlserver。推荐最好不要这样写。最好写成inner join的写法。内连接查询 (select * from a join b on a.id b.id) 与 关联查询 (select * from a , b where a.id b.id)的区别left join,在两张表进行连接查询时会返回左表所有的行即使在右表中没有匹配的记录。我们使用left join对两张表进行连接查询sql如下SELECT p.LastName, p.FirstName, o.OrderNo FROM Persons p LEFT JOIN Orders o ON p.Id_Po.Id_P ORDER BY p.LastName查询结果如下可以看到左表Persons表中LastName为Bush的行的Id_P字段在右表Orders表中没有匹配但查询结果仍然保留该行。right join,在两张表进行连接查询时会返回右表所有的行即使在左表中没有匹配的记录。我们使用right join对两张表进行连接查询sql如下SELECT p.LastName, p.FirstName, o.OrderNo FROM Persons p RIGHT JOIN Orders o ON p.Id_Po.Id_P ORDER BY p.LastName查询结果如下Orders表中最后一条记录Id_P字段值为65在左表中没有记录与之匹配但依然保留。full join,在两张表进行连接查询时返回左表和右表中所有没有匹配的行。我们使用full join对两张表进行连接查询sql如下SELECT p.LastName, p.FirstName, o.OrderNo FROM Persons p FULL JOIN Orders o ON p.Id_Po.Id_P ORDER BY p.LastName查询结果如下查询结果是left join和right join的并集。4、使用联合(UNION)来代替手动创建的临时表MySQL从4.0版本开始支持union查询他可以把需要使用临时表的两条或更多的select查询合在一个查询中。在客户端查询会话结束的时候临时表会被自动删除从而保证数据库整齐、高效。使用union来创建查询的时候我们只需要用union作为关键字把多个select语句连接起来就可以了要注意的是所有select语句中的字段数目要相同。下面一个例子就演示了一个使用union额查询。当我们可以确认不可能出现重复结果集或者不在乎重复结果集的时候尽量使用union all而不是union因为union和union all的差异主要是前者需要将两个或者多个结果集合并后再进行唯一性过滤操作这就会涉及到排序增加大量的CPU运算增大资源消耗及延迟。5、事务尽管我们可以使用子查询(Sub-Queries)、连接(JOIN)和联合(UNION)来创建各种各样的查询但不是所有的数据库操作都可以只用一条或少数几条就可以完成的。更多的时候是需要用一系列的语句来完成某种工作。但是在这种情况下当这个语句块中的某一条语句运行出错的时候整个语句块的操作就会变得不确定起来。设想一下要把某个数据同时插入两个相关联的表中可能会出现这样的情况第一个表中成功更新后数据库突然出现意外状况造成第二个表中的操作没有完成这样就会造成数据的不完整甚至会破坏数据库中的数据。要避免这种情况就应该使用事务它的作用是要么语句块中每条语句都操作成功要么都失败。换句话说就是可以保持数据库中的数据的一致性和完整性。事务以BEGIN关键字开始COMMIT关键字结束。在这之间的一条SQL语句操作失败那么Rollback命令就可以把数据库恢复到begin开始之前的状态。BEGIN;  INSERTINTOsalesinfoSETCustomerID14; UPDATEinventorySETQuantity11WHEREitembook; COMMIT;事务的另一个作用是当多个用户同时使用相同的数据源时他可以使用锁定数据库的方式来为用户提供一种安全的访问机制这样可以保证用户的操作不被其它的用户所干扰。一般来说事务必须满足四个条件(ACID)原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability).原子性一个事物(transaction)中的所有操作要么全部完成要么全部不完成不会结束在中间某个环节。事务在执行过程中发生错误会被回滚(Rollback)到事务开始的状态就像这个事务从来没有执行过一样。一致性在事务开始之前和事务结束之后数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作。隔离性数据库允许多个事务同时对其数据进行读写和修改的能力隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同的级别包括读未提交(Read uncommitted)、读已提交(Read committed)、可重复读(repeateable read)和串行化(Serializable).持久性事务处理结束后对数据的修改就是永久的即便系统故障也不会丢失。事务的并发问题1、脏读事务A读取了事务B更新的数据然后B回滚操作那么A读取到的数据就是脏数据2、不可重复读事务A多次读取同一事物事务B在事务A多次读取的过程中对数据做了更新并提交导致事务A多次读取同一数据时结果不一致。3、幻读系统管理员A将数据库中的所有学生的成绩从具体分数改为ABCDE等级但是系统管理员B就在这个时候插入了一条具体分数的记录当系统管理员A改结束后发现还有一条记录没有改过来就好像发生了幻觉一样这就叫幻读。小结不可重复读的和幻读很容易混淆不可重复读侧重于修改幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行解决幻读需要锁表MySQL事务隔离级别事务隔离级别脏读不可重复读幻读读未提交read-uncommitted是是是不可重复读read-committed否是是可重复读repeatable-read否否是串行化serializable否否否事务控制语句BEGIN或START TRANSACTION显式的开启一个事物。COMMIT也可以使用COMMIT WORK不过二者是等价的。COMMIT会提交事务并使已对数据库进行的所有修改成为永久性的。Rollback也可以使用Rollback work不过二者是等价的。回滚会结束用户的事务并撤销正在进行的所有未提交的修改。SAVEPOINT identifierSAVEPOINT允许在事务中创建一个保存点一个事务中可以有很多个SAVEPOINTRELEASE SAVEPOINT identifier删除一个事物的保存点,当没有指定的保存点时执行该语句会抛出一个异常。ROLLBACK TO inditifier把事务回滚到标记点。SET TRANSACTION:用来设置事务的隔离级别。InnoDB存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERLALIZABLE。6、使用外键锁定表的方法可以维护数据的完整性但是他却不能保证数据的关联性。这个时候我们可以使用外键。例如外键可以保证每一条销售记录都指向某一个存在的客户。在这里外键可以把customerinfo表中的customerid映射到salesinfo表中customerid任何一条没有办法合法customerid的记录都不会被跟新或插入到salesinfo中.CREATE TABLE customerinfo(customerid int primary key) engine  innodb; CREATE  TABLE   salesinfo( salesid int not null,customerid  int not null, primary key(customerid,salesid),foreign key(customerid)  references  customerinfo(customerid) on delete cascade)engine  innodb;注意例子中的参数“on delete cascade”.该参数保证当customerinfo表中的一条客户记录也会被自动删除。如果要在mysql中使用外键一定要记住在创建表的时候将表的类型定义为事务安全表InnoDB类型。该类型不是mysql表的默认类型。定义的方法是在CREATE TABLE语句中加上engineinnoDB。7、锁定表尽管事务是维护数据库完整性的一个非常好的方法但却因为他的独占性有时会影响数据库的性能尤其是很大的应用系统中。由于在事务执行的过程中数据库将会被锁定因此其他的用户请求只能暂时等待直到该事务结束。如果一个数据库系统只有少数几个用户来使用事务造成的影响不会成为太大的问题但假设有成千上万的用户同时访问一个数据库系统例如访问一个电子商务网站就会产生比较严重的响应延迟。其实有些情况下我们可以通过锁定表的方式来获得更好的性能。下面的例子就是锁定表的方法来完成前面一个例子中事务的功能。这里我们用一个select语句取出初始数据通过一些计算用update语句将新值更新到表中。包含有WRITE关键字的LOCKTABLE语句可以保证在UNLOCKTABLES命令被执行之前不会有其他访问来对inventory进行插入、更新或者删除的操作。8、使用索引索引是提高数据库性能的常用方法他可以令数据库服务器比没有索引快得多的速度检索特定的行尤其是在查询语句当中包含有MAX(),MIN()和ORDERBY这些命令的时候性能提高更为明显。那该对那些字段进行索引呢一般来说索引应该建立在那些将用于joinwhere判断和orderby排序的字段上。尽量不要对数据库中某个含有大量重复的值的字段建立索引对于一个ENUM类型的字段来说出现大量重复值是很有可能的情况。例如customerinfo中的“province”..字段在这样的字段上建立索引将不会有什么帮助相反还有可能降低数据库的性能。我们在创建表的时候可以同时创建合适的索引也可以使用ALTERTABLE或CREATEINDEX在以后创建索引。此外MySQL从版本3.23.23开始支持全文索引和搜索。全文索引在MySQL中是一个FULLTEXT类型索引但仅能用于MyISAM类型的表。对于一个大的数据库将数据装载到一个没有FULLTEXT索引的表中然后再使用ALTERTABLE或CREATEINDEX创建索引将是非常快的。但如果将数据装载到一个已经有FULLTEXT索引的表中执行过程将会非常慢。9、优化de的查询语句不使用子查询例SELECT * FROM t1 WHERE id (SELECT id FROM t2 WHERE name’hechunyang’);子查询在MySQL5.5版本里内部执行计划器是这样执行的先查外表再匹配内表而不是先查内表t2当外表的数据很大时查询速度会非常慢。在MariaDB10/MySQL5.6版本里采用join关联方式对其进行了优化这条SQL会自动转换为SELECT t1.* FROM t1 JOIN t2 ON t1.id  t2.id;但请注意的是优化只针对SELECT有效对UPDATE/DELETE子查询无效固生产环境应避免使用子查询避免函数索引例SELECT * FROM t WHERE YEAR(d)  2016;由于MySQL不像Oracle那样支持函数索引即使d字段有索引也会直接全表扫描。应改为—–SELECT * FROM t WHERE d  2016-01-01;用IN来替换OR低效查询SELECT * FROM t WHERE LOC_ID  10 OR LOC_ID  20 OR LOC_ID  30;—– 高效查询SELECT * FROM t WHERE LOC_IN IN (10,20,30);LIKE双百分号无法使用到索引SELECT * FROM t WHERE name LIKE ‘%de%’;—–SELECT * FROM t WHERE name LIKE ‘de%’;目前只有MySQL5.7支持全文索引支持中文读取适当的记录LIMIT M,NSELECT * FROM t WHERE 1;—–SELECT * FROM t WHERE 1 LIMIT 10;避免数据类型不一致SELECT * FROM t WHERE id  ’19’;—–SELECT * FROM t WHERE id  19;分组统计可以禁止排序SELECT goods_id,count(*) FROM t GROUP BY goods_id;默认情况下MySQL对所有GROUP BY col1col2…的字段进行排序。如果查询包括GROUP BY想要避免排序结果的消耗则可以指定ORDER BY NULL禁止排序。另外MySQL 系列面试题和答案全部整理好了微信搜索Java技术栈在后台发送面试可以在线阅读。—–SELECT goods_id,count(*) FROM t GROUP BY goods_id ORDER BY NULL;避免随机取记录SELECT * FROM t1 WHERE 11 ORDER BY RAND() LIMIT 4;MySQL不支持函数索引会导致全表扫描 —–SELECT * FROM t1 WHERE id  CEIL(RAND()*1000) LIMIT 4;禁止不必要的ORDER BY排序SELECT count(1) FROM user u LEFT JOIN user_info i ON u.id  i.user_id WHERE 1  1 ORDER BY u.create_time DESC;—–SELECT count(1) FROM user u LEFT JOIN user_info i ON u.id  i.user_id;批量INSERT插入INSERT INTO t (id, name) VALUES(1,’Bea’); INSERT INTO t (id, name) VALUES(2,’Belle’); INSERT INTO t (id, name) VALUES(3,’Bernice’);—–INSERT INTO t (id, name) VALUES(1,’Bea’), (2,’Belle’),(3,’Bernice’);来源 | 臆想的一只猫 | urls.press/0Y9x0END往期推荐MyBatis原生批量插入的坑与解决方案面试官怎么解决MySQL中的死锁问题再见收费的Navicat操作所有数据库靠它就够了
http://www.sadfv.cn/news/110001/

相关文章:

  • 河北建设工程招标投标协会网站上海协策网站
  • 贵阳网站建设培训班温州市鹿城区建设小学网站
  • 如何做盗版视频网站交流网站建设心得体会
  • 永康物流网站开发平台网站建设目标概括
  • 企业网站建设 电脑配置花店网页制作素材
  • 微商城网站建设价位济南网络科技公司排名
  • 中山网站备案只有网站才需要域名吗
  • 网站建设官网怎么收费展示型网站与营销型网站
  • 做网站编辑是不是也要做推广企业图标设计大全
  • 网站开发设计文档域名名称是什么
  • 网站建设预算模板大型网站建设企业名录模板
  • 广州注册公司核名在哪个网站岳阳网站开发服务
  • 国外源代码下载网站杭州网站建设模板
  • 网站开发备案费用建立个人网站用虚拟主机
  • 大连企业网站开发移动网站seo
  • 电话销售做网站网站建设柒首先金手指8
  • 网站建设交互效果软件工程考研难度
  • 想做一个什么样的网站静安正规的设计公司网站
  • 专业手机建站公司网上推广赚钱方法
  • 南昌地宝网租房个人房源潍坊百度推广优化
  • 做外贸自己公司的网站一定要吗昆明网站网站建设
  • 免费网站空间免备案南京 seo 价格
  • wordpress商品展示插件泰安网络优化
  • 中国建设银行官网站金银纪念币什么平台可以打广告做宣传
  • 湖南移动网站建设公司免费网站搭建
  • 广东网页设计培训徐州seo推广
  • 山东华邦建设集团网站手机网站开发技术pdf
  • 网站留言板html模板腾讯公司网页
  • 博创网站建设团队新闻类网站的设计
  • 网站广告的优势十大营销手段