设为首页 收藏本站
查看: 1205|回复: 1

[经验分享] 【原】无脑操作:express + MySQL 实现CRUD

[复制链接]

尚未签到

发表于 2017-12-13 13:47:25 | 显示全部楼层 |阅读模式
  基于node.js的web开发框架express简单方便,很多项目中都在使用。这里结合MySQL数据库,实现最简单的CRUD操作。
DSC0000.jpg

  开发环境:
  IDE:WebStorm
  DB:MySQL
  -------------------------------------------------------------------------------------------
  1、使用WebStorm创建node.js express应用程序,express框架可以根据使用者的爱好设置页面引擎,默认为jade,我比较喜欢ejs,这里设置时选择Template为EJS即可
  这里WebStorm实际使用了express-generator这个生成器为我们生成了express应用程序
DSC0001.jpg

  2、创建结束时,可以看到express工程结构如图
DSC0002.jpg

  3、执行调试的设置(不设置也可以,只不过执行或调试时看的有些奇怪而已)
DSC0003.jpg

  修改一下Name的内容为工程名称
  注意:express工程中的bin目录下有一个www文件,它用来设置express工程的一些配置,比如express引用程序的端口(默认:3000)等
DSC0004.jpg

  4、配置好后就可以执行(alt+F10)或调试(alt+F9)了
DSC0005.jpg

  5、试着访问一下,在浏览器的地址栏中输入localhost:3000,可以看到下图,说明express框架的应用程序已经搭建好了
DSC0006.jpg

  -------------------------------------------------------------------------------------------
  6、express-generator生成器生成的代码中有users相关内容,我们不需要的,所以删除之。先在app.js这个文件中删除相关内容,下图中的第9行和第26行都删除掉
DSC0007.jpg

  7、另外,路由目录routes中的users.js文件也删除掉
DSC0008.jpg

  -------------------------------------------------------------------------------------------
  8、接着添加MySQL数据库驱动,在package.json文件中添加"mysql" : "latest",意思是不知道mysql对应的驱动是什么版本,使用latest表示获取最新的mysql数据库驱动
DSC0009.jpg

  9、观察一下工程目录中的node_modules目录,现在是没有mysql驱动的
DSC00010.jpg

  10、在命令行窗口中当前工程路径下使用指令:npm install,这样就可以依据package.json文件中写的依赖添加mysql驱动了
DSC00011.jpg

  添加完毕,如下提示
DSC00012.jpg

  再次观察node_modules目录,这时有mysql驱动了
DSC00013.jpg

  -------------------------------------------------------------------------------------------
  11、最终实现的效果
  【客户信息列表页面】
DSC00014.jpg

  【客户新增页面】
DSC00015.jpg

  【客户修改页面】
DSC00016.jpg

  【根据条件查询】
DSC00017.jpg

DSC00018.jpg

  -------------------------------------------------------------------------------------------
  12、创建数据访问层,在express工程中创建db目录,在其中创建两个文件dbconfig.js 和 customersql.js文件,dbconfig.js文件是MySQL数据库连接配置信息模块文件,customersql.js文件记录客户管理功能模块要用到的sql语句,当然都以JavaScript对象的形式,以node.js中模块的结构组织。
DSC00019.jpg

  对于数据库连接配置模块,还是那些连接信息:服务器名称啦、连接用户名称啦、连接用户密码啦、数据库名称啦、端口号啦
  而具体业务模块的数据库操作对象模块说白了就是对SQL语句进行了JavaScript对象方式的封装,调用时获取对象的CRUD相应的属性值(也就是相应的SQL语句)
  -------------------------------------------------------------------------------------------
  13、路由规划
  默认index.js文件如下,只有对默认路径(即http://localhost这样)形式访问的路由处理
DSC00020.jpg

  添加自定义的路由规划,包括路由对应的处理器函数,无非是对应页面的CRUD操作,设置get、post方式的处理器函数
DSC00021.jpg

  -------------------------------------------------------------------------------------------
  14、最终的工程结构
DSC00022.jpg

  看到这里,是不是感觉到特别无脑操作、特别简单呀?
  后续有空,再写一个更好一些的版本(涉及:分页、多表连接、Ajax等)
  整个工程代码:https://github.com/temptation/watermalon_v1

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-423663-1-1.html 上篇帖子: 配置EF链接 MySql 的方法 下篇帖子: MySQL版本升级5.6到5.7版本
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表