您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

Oracle中提取主键拼字符串的问题

2025/2/18 9:31:41发布23次查看
最近在做一个数据库是用的oracle的项目,也是我的第一个项目模块,感觉很蛋疼,但是有很多收获。下面就是我遇到的问题和解决方法
最近在做一个数据库是用的oracle的项目,也是我的第一个项目模块,感觉很蛋疼,但是有很多收获。下面就是我遇到的问题和解决方法,我是菜鸟级,希望高手如果发现错误,请指出。
比如:
创建的oracle的表,主键描述:“四位树形代码”
比如用户表中:
表名:user
表记录:
user_id char(15) not null,
user_name varchar2(20) not null,
user_email varchar2(30),
primary key(user_id)
先插入一条数据:
insert into user values('0001', '张三', '123456789@');
现在我要查询:
select * from user;
执行的结果:
user_id                             user_name                                  user_email
   0001                                          张三                                       123456789@
如果我们从oracle中只查询出user_id
select user_id
from user;
执行的结果:
user_id
   0001
但是在我们拼字符串sql的时候,比如我们要联表查询,user_id在另外一个表中是一个内联的字段,我们就要在user_id内联的表中使用到。
比如在“学生表”中:
表名:student
表记录:
student_id char(15) not null,
user_id char(15) not null,
student_name varchar2(20) not null,
primary key(student_id)
插入一条记录:
insert into student values('0001','0001' , '学生张三');
查询(这里的查询,我要信息中给学生分配邮箱信息)
select s.student_name, u.user_mail
from student s, user u
where s.user_id=u.user_id;
执行结果:
student_name                                               usermail
     学生张三                                                 123456789@163..com
重点:
在数据库中,直接这样用肯定是对的,如果我们在java文件中使用字符串sql进行拼字符串就会出现问题了。
使用jdbc连接,执行sql,返回查询结果,这里省略jdbc的处理
假设使用public list baselistsql(string sql); 方法处理。
拼sql的方法:
(1)
//这一句中user_name是传入的参数,根据传入的user的名字找到user_id的值
string usr_id = this.baselistsql(select user_id from user where user_name='+user_name+' );  
 //根据user_id关联user表中的user_mail
string sql = select s.student_name, u.user_mail from student s, user u where s.user_id='+user_id+';
//通过jdbc执行后返回list
list students = this.baselistsql(sql);
//返回数据
return  students;
分析:
直接看的时候,还认为这样的sql逻辑是对的,字符串也拼对了的,但是是不能执行成功的,当然你可以使用system.out.println(sql);和debug的模式进行调试,但是我这里记下,不想每次都因为这个错误去调试半天。
这里user_id是char类型,长度是15 , 我们使用“四位树形代码”输入的数据是'0001'这样当他查出来是'0001           ',后面全部都是空格,所以在下面拼的sql中传入的值就不正确了,,所以需要一定的处理,处理如方案(2)
(2)
//这一句中user_name是传入的参数,根据传入的user的名字找到user_id的值
string usr_id = this.baselistsql(select user_id from user where user_name='+user_name+' );  
//首先使用string的trim()方法去除所有空格,这样就正确了
user_id = user_id.trim();
 //根据user_id关联user表中的user_mail
string sql = select s.student_name, u.user_mail from student s, user u where s.user_id='+user_id+';
//通过jdbc执行后返回list
list students = this.baselistsql(sql);
//返回数据
return  students;
举例中可能会有错误,希望发现错误指出一下。
这样就可以执行成功了!找的时候没注意,幸苦死了,记录一下pass一下它!
下次有时间继续记录遇到的问题,哈哈!奖励一下自己!遇到得多解决得多,到时候一定要成为高手。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product