当前位置: 移动技术网 > IT编程>数据库>Mysql > web项目踩坑过程

web项目踩坑过程

2019年11月28日  | 移动技术网IT编程  | 我要评论

sql函数设计:

一开始本来是直接用java的jdbc直接传输操作语句的。但后来学了存储过程发现存储过程可以提高不少的效率。就重构了自己对数据库的操作代码。包括:开启,查找,修改,关闭。

开启:直接使用的构造函数,以后使用的时候可以直接把对象new成一个static的变量,可以一直使用,直到使用关闭函数。

 

具体操作(查(find),写(write),改(change)):编写的思路是现在mysql数据库里面实现函数和存储过程。

   巨坑提示1,存储过程和函数的区别是,函数必须返回一个数据,return语句必须写,而存储过程可以返回,也可以不返回这个数据。

   一开始我使用的是存储过程,实现find,但是,有个巨坑的东西(mysql的设计缺陷,那就是in的变量,即存储过程名旁边的参数,不可以直接表示字段,巨坑,还要深入学习动态的sql才可以表示字段),然后我就多写了几个函数,每个函数实现不同字段的查询,比如,findbyemail函数就是通过where email(email是字段)=参数;实现查找。

   然后为了让功能齐全,就设计了多个函数,比如findbyname,findbyphone这些函数存在数据库里。然后数据库编译好。等着java直接调用(这里比较方便的就是我们的调用直接用的是调用语句 "{call 函数名(?)}",这里的?问号,是指的你的参数。也意味着你的存储过程或者函数有多少参数就必须用多少个问号,然后发送给数据库。性能提高不少)

                              

  巨坑提示2,在发送调用存储过程的sql语句的过程中,有可能会出现引号(')解析错位的尴尬错误,而且我还没办法纠正。比如writeuser存储过程,发送过去的语句被解析错了,就是引号错位。卡了我一上午的时间。然后就使用的函数,放弃使用存储过程。性能影响比较小。还可以返回一个数据可以判断一下。比如我的writeuser函数,我可以这样写,就不会出现这样尴尬的错误了

                                 string  sql = “{?=call writeuser(?????)}”;

 1 public string writeuser(string name,string phone,string email,string pwd,string status) throws sqlexception {
 2         //使用方法:比如写入用户数据name,phone,email,pwd,status,我们可以这样写write('张三','110','110@qq.com','999','1')
 3 
 4         string sql = "{? = call writeuser(?,?,?,?,?)}";
 5 
 6         callablestatement cs = connection.preparecall(sql);
 7 
 8         cs.registeroutparameter(1,types.char);//这里实在规定你函数里面返回的数据类型
 9 
10         cs.setstring(2,name);//以下都是在向问号里面传递参数
11 
12         cs.setstring(3,phone);
13 
14         cs.setstring(4,email);
15 
16         cs.setstring(5,pwd);
17 
18         cs.setstring(6,status);
19 
20         cs.execute();
21 
22         string value = cs.getstring(1);
23         if (value=="1"){
24             cs.close();
25             return "ok";
26         }
27         cs.close();
28         return "no";
29     }

 

  

 

如对本文有疑问, 点击进行留言回复!!

相关文章:

  • mysql解决时区相关问题

    前言:在使用 mysql 的过程中,你可能会遇到时区相关问题,比如说时间显示错误、时区不是东八区、程序取得的时间和数据库存储的时间不一致等等问题。其实,这些问题... [阅读全文]
  • MySQL8.0内存相关参数总结

    mysql理论上使用的内存 = 全局共享内存 + max_connections×线程独享内存。也就是:innodb_buffer_pool_size + in... [阅读全文]
  • mysql如何查询日期与时间

    前言: 在项目开发中,一些业务表字段经常使用日期和时间类型,而且后续还会牵涉到这类字段的查询。关于日期及时间的查询等各类需求也很多,本篇文章简单讲讲日期及时间字... [阅读全文]
  • 深入了解mysql长事务

    前言: 本篇文章主要介绍mysql长事务相关内容,比如说我们开启的一个事务,一直没提交或回滚会怎样呢,出现事务等待情况应该如何处理,本篇文章将给你答案。注意:本... [阅读全文]
  • 详解mysql DML语句的使用

    前言: 在上篇文章中,主要为大家介绍的是ddl语句的用法,可能细心的同学已经发现了。本篇文章将主要聚焦于dml语句,为大家讲解表数据相关操作。这里说明下ddl与... [阅读全文]
  • JDBC怎么连接数据库

    JDBC的快速入门(写这个东西是为了自己记一个笔记,或者为了方便别人应付作业)你要连接什么数据库就要下载什么类型... [阅读全文]
  • 高性能Mysql的逻辑架构和常见的存储引擎

    高性能Mysql的逻辑架构和常见的存储引擎

    前言: 为了充分发挥MySQL的性能并顺利地使用,就必须理解其设计。MySQL的灵活性体现在很多方面。例如,... [阅读全文]
  • 如何选择合适的MySQL日期时间类型来存储你的时间

    构建数据库写程序避免不了使用日期和时间,对于数据库来说,有多种日期时间字段可供选择,如 timestamp 和 datetime 以及使用 int 来存储 un... [阅读全文]
  • MySQL数据库使用规范总结

    导读: 关于mysql数据库规范,相信大家多少看过一些文档。本篇文章给大家详细分类总结了数据库相关规范,从库表命名设计规范讲起,到索引设计规范,后面又给出sql... [阅读全文]
  • 详解MySQL 外键约束

    官方文档:1.外键作用:mysql通过外键约束来保证表与表之间的数据的完整性和准确性。2.外键的使用条件 两个表必须是innodb表,myisam表暂时不支持... [阅读全文]
验证码:
移动技术网