最近自学的时候遇到了这么一个问题……
首先,任务要求是这样的:
1.在数据库中新建一个用户状态表。里面包含2个字段。user_status(userid bigint,status int)
userid为自增。
status默认为0;
插入1000条记录。
2.写一个存储过程,从user_status表中获取一条status=0的userid字段的值,取出userid时,需要同时把这条记录对应的status从0修改为1.
3.开启2个线程,在线程中循环调用第2步中的存储过程,直到user_status表中记录全部取完(即status全部为1)。要求:在2个线程中取出的userid不能重复。并把取出的userid,打印到某个文件中,一行一个userid
我的存储过程:
ALTER procedure [dbo].[sp_getuserid] as declare @userid int declare @count int set @count=1 Begin TransAction select top 1 @userid=userid from user_status where status=0 update user_status set status=1 where status=0 and userid =@userid set @count = @@ROWCOUNT If @count=0 begin rollback TransAction return 0 end Else Begin select userid from user_status where userid=@userid Commit TransAction End
java的程序代码:
public class Status implements Runnable { private int num; @Override public void run() { Boolean flag = true; while(flag) { this.writeFile(this.getUserid()); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } } @SuppressWarnings("unchecked") public List<UserBean> getUserid() { // 创建数据库连接 Connection conn = ConnectDb.Connect(); QueryRunner qRunner = new QueryRunner(); List<UserBean> list = new ArrayList<UserBean>(); try { list = qRunner.query(conn, "exec sp_getuserid", new BeanListHandler(UserBean.class)); } catch (Exception e) { e.printStackTrace(); } DbUtils.closeQuietly(conn); return list; } public Boolean writeFile(List<UserBean> list) { File file = new File("d:/test.txt"); if (!file.exists()) try { file.createNewFile(); } catch (IOException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } if (list==null||list.size()==0) return false; else { try { FileOutputStream out = new FileOutputStream(file, true); for (int i = 0; i < list.size(); i++) { System.out.println("userId:"+list.get(i).getUserid()+""); StringBuffer sb = new StringBuffer(); SimpleDateFormat df = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss:SSS"); sb.append(df.format(new Date()) + " \t" + list.get(i).getUserid()+ " \t"+this.getNum()); sb.append(System.getProperty("line.separator")); out.write(sb.toString().getBytes("utf-8")); } out.close(); return true; } catch (Exception e) { e.printStackTrace(); return true; } } } public static void main(String[] args) { for(int j=0;j<50;j++){ System.out.println("status["+j+"]"+" start!"); new Thread(new Status(j)).start(); } } public int getNum() { return num; } public void setNum(int num) { this.num = num; } public Status(int num) { this.num=num; } }
如何解决并发问题啊,我在隔壁也问过这个问题,但是要求是不能增加字段啊……也许是我写的方法太烂了……
现在结果是:在txt中缺少几条数据,但在数据库中已经更新了……也就是说,某些条目虽然在数据库中更新了,但并没有写入到txt中。
相关推荐
Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...
Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...
Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...
Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...
Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...
Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...
Java访问权限控制源代码 1个目标文件 摘要:Java源码,文件操作,权限控制 Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流...
java.sql 提供使用 JavaTM 编程语言访问并处理存储在数据源(通常是一个关系数据库)中的数据的 API。 java.text 提供以与自然语言无关的方式来处理文本、日期、数字和消息的类和接口。 java.text.spi java.text ...
Java访问权限控制源代码 1个目标文件 摘要:Java源码,文件操作,权限控制 Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流...
java.sql 提供使用 JavaTM 编程语言访问并处理存储在数据源(通常是一个关系数据库)中的数据的 API。 java.text 提供以与自然语言无关的方式来处理文本、日期、数字和消息的类和接口。 java.text.spi java.text ...
java.sql 提供使用 JavaTM 编程语言访问并处理存储在数据源(通常是一个关系数据库)中的数据的 API。 java.text 提供以与自然语言无关的方式来处理文本、日期、数字和消息的类和接口。 java.text.spi java.text ...
java.sql 提供使用 JavaTM 编程语言访问并处理存储在数据源(通常是一个关系数据库)中的数据的 API。 java.text 提供以与自然语言无关的方式来处理文本、日期、数字和消息的类和接口。 java.text.spi java.text ...
java.sql 提供使用 JavaTM 编程语言访问并处理存储在数据源(通常是一个关系数据库)中的数据的 API。 java.text 提供以与自然语言无关的方式来处理文本、日期、数字和消息的类和接口。 java.text.spi java.text ...
【多线程】简述synchronized 和java.util.concurrent.locks.Lock的异同? 90 【线程】ThreadLocal的作用 90 【Spring】什么是IOC和DI?DI是如何实现的 91 【Spring】spring中的IOC(控制反转)的原理 92 【Spring】...
java.sql 提供使用 JavaTM 编程语言访问并处理存储在数据源(通常是一个关系数据库)中的数据的 API。 java.text 提供以与自然语言无关的方式来处理文本、日期、数字和消息的类和接口。 java.text.spi java.text ...
java.sql 提供使用 JavaTM 编程语言访问并处理存储在数据源(通常是一个关系数据库)中的数据的 API。 java.text 提供以与自然语言无关的方式来处理文本、日期、数字和消息的类和接口。 java.text.spi java.text ...